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1.0 


Definitions, symbols, abbreviations, keywords, and conventions 


This clause contains the definitions, symbols, abbreviations, keywords and, conventions used throughout this 
manual. These items are from the American National Standards Institute T10 committee as referenced in the 
SCSI Primary Commands SPC-4 rev 2 draft and the SCSI Block Commands SBC -2 rev 16 draft. 

Applicable Documents: 

T10/1416-D SCSI Primary Commands - 3 (SPC-3) Revision 23 

T10/1731-D SCSI Primary Commands - 4 (SPC-4) Revision 2 

TIO/xxxx-D SCSI Block Commands - 3 (SBC-3) Revision 2 

T10/1560-D Fibre Channel Protocol for SCSI, Third Editon (FCP-3) Revision 4 

T10/1760-D Serial Attached SCSI - 2 (SAS-2) Revision 00 

T10/1683-D SCSI Architecure Model - 4 (SAM-4) Revision 3 


SCSI Commands Reference Manual, Rev. A 


1 



1.1 Definitions 

Access control list (ACL) 

The data used by a SCSI target device to configure access rights for initiator ports according to the access 
controls state of the SCSI target device. 

Access control list entry (ACE) 

One entry in the access control list. 

Access controls 

An optional SCSI target device feature that restricts initiator port access to specific logical units and modi¬ 
fies the information about logical units in the parameter data of the INQUIRY and REPORT LUNS com¬ 
mands. 

Access controls coordinator 

The entity within a SCSI target device that coordinates the management and enforcement of access con¬ 
trols for all logical units within the SCSI target device. The access controls coordinator is always address¬ 
able through the ACCESS CONTROLS well known logical unit and LUN 0. 

active power condition 

When a device server is capable of responding to all of its supported commands, including media access 
requests, without delay. 

additional sense code 

A combination of the ADDITIONAL SENSE CODE and ADDITIONAL SENSE CODE QUALIFIER fields in 
the sense data. 

Alias list 

A list of alias values and their associated designations maintained by the device server and managed by 
the CHANGE ALIASES command and REPORT ALIASES command. 

Alias value 

A numeric value associated to a designation in the alias list and used in command or parameter data to ref¬ 
erence a SCSI target device or SCSI target port. 

Application client 

An object that is the source of SCSI commands. Further definition of an application client may be found in 
SAM-3. 

Attached medium changer 

A medium changer that is attached to and accessed through some other type of SCSI device. 

Attribute 

A single unit of MAM information. 

Auto contingent allegiance (ACA) 

The task set condition established following the return of a CHECK CONDITION status when the NACA bit 
is set to one in the CONTROL byte. A detailed definition of ACA may be found in SAM-3. 

Blocked task 

A task that is in the blocked state. Tasks become blocked when an ACA condition occurs. The blocked 
state ends when the ACA condition is cleared. A detailed definition of the blocked task state may be found 
in SAM-3. 

Byte 

A sequence of eight contiguous bits considered as a unit. 

Cache 

See cache memory. 
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Cache memory 

A temporary and often volatile data storage area outside the area accessible by application clients that 
may contain a subset of the data stored in the non-volatile data storage area. 

Check data 

Information contained within a redundancy group that may allow lost or destroyed XOR-protected data to 
be recreated. 

Command 

A request describing a unit of work to be performed by a device server. A detailed definition of a command 
may be found in SAM-3. 

Command descriptor block (CDB) 

The structure used to communicate commands from an application client to a device server. A CDB may 
have a fixed length of up to 16 bytes or a variable length of between 12 and 260 bytes. 

Command standard 

A SCSI standard that defines the model, commands, and parameter data for a device type (e.g., SBC-2, 
SSC-2, SMC-2, MMC-4, or SES-2). 

Companyjd 

Synonym for OUI. 

Control mode page 

A mode page that provides controls over SCSI features (e.g., task set management and error logging) that 
are applicable to all device types. 

Control Extension mode page 

A mode page that provides controls over SCSI features that are applicable to all device types. 

Copy manager 

The device server that receives an EXTENDED COPY command and performs the operation requested. 

Copy target device 

The name given by the EXTENDED COPY command to a source or destination logical unit (i.e., a copy 
target device is a logical unit, not a SCSI target device). 

Cyclic redundancy check (CRC) 

An error checking mechanism that checks data integrity by computing a polynomial algorithm based 
checksum. 

Data defect list (DLIST) 

A list of defects sent by the application client to the device server during a FORMAT UNIT command. 

Data-in buffer 

The buffer specified by the application client to receive data from the device server during the processing 
of a command. 

Data-out buffer 

The buffer specified by the application client to supply data that is sent from the application client to the 
device server during the processing of a command. 

Default protection information 

Values placed into protection information fields if an application client does not specify specific protection 
information values. 

Deferred error 

A CHECK CONDITION status and sense data that is returned as the result of an error or exception condi¬ 
tion that occurred during processing of a previous command for which GOOD, CONDITION MET, INTER¬ 
MEDIATE, and INTERMEDIATE-CONDITION MET status has already been returned. 
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Designation 

When used in reference to access controls, a name and optional identifier information that specifies a 
SCSI target device or SCSI target port for association with an alias value in the alias list. Otherwise, a dis¬ 
tinguishing name, identifier, or title. 

Device Identification VPD page 

A VPD page that provides the means to retrieve identification information about the SCSI device, logical 
unit, and SCSI port. 

Device server 

An object within a logical unit that processes SCSI tasks according to the rules of task management. A 
detailed definition of a device server may be found in SAM-3. 

Device service request 

A request, submitted by an application client, conveying a SCSI command to a device server. A detailed 
definition of a device service request may be found in SAM-3. 

Device service response 

The response returned to an application client by a device server on completion of a SCSI command. A 
detailed definition of a device service response may be found in SAM-3. 

Device type 

The type of peripheral device (i.e., device model) implemented by the device server and indicated by the 
contents of the PERIPHERAL DEVICE TYPE field in the standard INQUIRY data. 

Direct-access block device 

A device that is capable of containing data stored in blocks that each have a unique logical block address. 

Disconnect-Reconnect mode page 

A mode page that provides the application client the means to tune the performance of the service delivery 
subsystem. 

Domain 

An I/O system consisting of a set of SCSI devices that interact with one another by means of a service 
delivery subsystem. 

Element 

An addressable physical component of a medium changer SCSI device that may serve as the location of a 
removable unit of data storage medium. A detailed definition of an element may be found in SMC-2. 

Enabled task state 

The only task state in which a task may make progress towards completion. A detailed definition of the 
enabled task state may be found in SAM-3. 

Error correcting code (ECC) 

An error checking mechanism that checks data integrity and enables some errors in the data to be cor¬ 
rected. 

Exclusive-or (XOR) 

A Boolean arithmetic function on two binary input values that results in an output value of 1 if one and only 
one of the input values is 1. 

Extended Unique Identifier, a 48-bit globally unique identifier (EUI-48) 

The IEEE maintains a tutorial describing EUI-48 at http://standards.ieee.org/regauth/oui/tutorials/ 

EUI48.html. 

Extended Unique Identifier, a 64-bit globally unique identifier (EUI-64) 

The IEEE maintains a tutorial describing EUI-64 at http://standards.ieee.org/regauth/oui/tutorials/ 

EUI64.html. 
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Extent 

A fixed set of logical blocks occupying contiguous logical block addresses on a single logical unit. 

Faulted l_T nexus 

The l_T nexus on which a CHECK CONDITION status was returned that resulted in the establishment of 
an ACA. The faulted l_T nexus condition is cleared when the ACA condition is cleared. 

Field 

A group of one or more contiguous bits, a part of a larger structure such as a CDB or sense data. 

Format corrupt 

a vendor-specific condition in which the application client may not be able to perform read operations, write 
operations, or verify operations. 

Grown defect list (GLIST) 

All defects sent by the application client to the device server. 

Hard reset 

A condition resulting from the events defined by SAM-3 in which the SCSI device performs the hard reset 
operations described in SAM-3, the standard, and the applicable command standards. 

Host 

A SCSI device with the characteristics of a primary computing device, typically a personal computer, work¬ 
station, server, minicomputer, mainframe computer, or auxiliary computing device. A host includes one or 
more SCSI initiator devices. 

IEEE companyjd 

Synonym for OUI. 

I_T nexus 

A nexus between a SCSI initiator port and a SCSI target port. 

I_T nexus loss 

A condition resulting from the events defined by SAM-3 in which the SCSI device performs the l_T nexus 
loss operations described in SAM-3, the standard, and the applicable command standards. 

I_T_L nexus 

A nexus between a SCSI initiator port, a SCSI target port, and a logical unit. 

I_T_L_Q nexus transaction 

The information transferred between SCSI ports in a single data structure with defined boundaries (e.g., an 
information unit). 

Idle power condition 

When a device server is capable of responding to all of its supported commands, including media access 
requests, but commands may take longer to complete than when in the active power condition. 

Implicit head of queue 

An optional processing model for specified commands wherein the specified commands may be treated as 
if they had been received with a HEAD OF QUEUE task attribute. 

Initiator device name 

A SCSI device name of a SCSI initiator device or of a SCSI target/initiator device when operating as a 
SCSI initiator device. 

Initiator port 

Synonymous with SCSI initiator port. 
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Initiator port identifier 

A value by which a SCSI initiator port is referenced within a SCSI domain. 

Initiator port name 

A SCSI port name of a SCSI initiator port or of a SCSI target/initiator port when operating as a SCSI initia¬ 
tor port. 

Internet protocol domain name 

The name of a computer or hierarchy of computers within the domain name system defined by the IETF 
(see RFC 1035 and RFC 1591). The Internet Assigned Numbers Authority maintains a list of domain name 
assignments at http://www.iana.org/assignments/domain-names. 

Internet protocol number 

A coded value assigned to identify protocols that layer on the Internet protocol (see RFC 791). The Internet 
protocol number assigned to the transmission control protocol (TCP, see RFC 793) is six. The Internet 
Assigned Numbers Authority maintains a list of Internet protocol number assignments at http:// 
www.iana.org/assignments/protocol-numbers. 

Linked command 

One in a series of SCSI commands processed by a single task that collectively make up a discrete I/O 
operation. A detailed definition of a linked command may be found in SAM-3. 

Least significant bit (LSB) 

In a binary code, the bit or bit position with the smallest numerical weighting in a group of bits that, when 
taken as a whole, represent a numerical value (e.g., in the number 0001 b, the bit that is set to one). 

Left-aligned 

A type of field containing ASCII data in which unused bytes are placed at the end of the field (highest off¬ 
set) and are filled with ASCII space (20h) characters. 

Logical block 

A set of data bytes accessed and referenced as a unit. 

Logical block address (LBA) 

The value used to reference a logical block. 

Logical unit 

An externally addressable entity within a SCSI target device that implements a SCSI device model and 
contains a device server. A detailed definition of a logical unit may be found in SAM-3. 

Logical unit access control descriptor (LUACD) 

The structure within an ACE that identifies a logical unit to which access is allowed and specifies the LUN 
by which the logical unit is to be accessed. 

Logical unit certification list (CLIST) 

Defects detected by the device server during an optional certification process performed during the FOR¬ 
MAT UNIT command. 

Logical unit inventory 

The list of the logical unit numbers reported by a REPORT LUNS command. 

Logical unit number (LUN) 

An encoded 64-bit identifier for a logical unit. A detailed definition of a logical unit number may be found in 
SAM-3. 

Logical unit reset 

A condition resulting from the events defined by SAM-3 in which the logical unit performs the logical unit 
reset operations described in SAM-3, the standard, and the applicable command standards. 
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Media 

Plural of Medium 

Medium 

A physical entity that stores data in a nonvolatile manner (i.e., retained through a power cycle) in accor¬ 
dance with commands processed by the device server. 

Medium auxiliary memory (MAM) 

An auxiliary memory residing on a medium that is accessible to the device server (e.g., a tape cartridge). 
Medium auxiliary memory may be nonvolatile and independent of the main function of the device server. 

Medium changer 

A device that mechanizes the movement of media to and from the SCSI device that records on or reads 
from the media. A detailed definition of a medium changer may be found in SMC-2. 

Most significant bit (MSB) 

In a binary code, the bit or bit position with the largest numerical weighting in a group of bits that, when 
taken as a whole, represent a numerical value (e.g., in the number 1000b, the bit that is set to one). 

Name 

A label of an object that is unique within a specified context and should never change (e.g., the term name 
and worldwide identifier (WWID) may be interchangeable). 

Network address authority (NAA) 

A field within a name that specifies the format and length of that name. See FC-FS. 

Nexus 

A relationship between two SCSI devices, and the SCSI initiator port and SCSI target port objects within 
those SCSI devices. 

Non-volatile cache 

Cache that retains data through power cycles. 

Non-volatile cache memory 

Cache memory that retains data through power cycles. 

Non-volatile medium 

A physical storage medium that retains data written to it for subsequent read operations through power 
cycles (e.g., a disk within a device that stores data as magnetic field changes that do not require device 
power to exist). 

Null-padded 

A type of field in which unused bytes are placed at the end of the field (i.e., highest offset) and are filled 
with ASCII null (OOh) characters. 

Null-terminated 

A type of field in which the last used byte (i.e., highest offset) is required to contain an ASCII null (OOh) 
character. 

One 

The logical true condition of a variable. 

Operation Code 

The first byte of a SCSI CDB shall contain an operation code identifying the operation being requested by the CDB. 

Organizationally unique identifier (OUI) 

A numeric identifier that is assigned by the IEEE such that no assigned identifiers are identical. OUI is 
equivalent to companyjd or IEEE companyjd. The IEEE prefers OUI for EUI-48 identifiers and 
companyjd for EUI-64 identifiers. However, the numeric identifier is called an OUI when it is assigned by 
the IEEE. The IEEE maintains a tutorial describing the OUI at http://standards.ieee.org/regauth/oui/. 
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Page 

A regular parameter structure (or format) used by several commands. These pages are identified with a 
value known as a page code. 

Persist through power loss 

An optional capability associated with some features that allows an application client to request that a 
device server maintain information regarding that feature across power failures. 

Persistent reservation holder 

The l_T nexus(es) that are allowed to release or change a persistent reservation without preempting it. 

Power cycle 

Power being removed from and later applied to a SCSI device. 

Power on 

A condition resulting from the events defined by SAM-3 in which the SCSI device performs the power on 
operations described in SAM-3, the standard, and the applicable command standards. 

Primary defect list (PLIST) 

The list of defects that are considered permanent defects. 

Protection information 

Fields appended to each logical block that contain a cyclic redundancy check (CRC), an application tag, 
and a reference tag. 

Protocol identifier 

A coded value used in various fields to identify the protocol to which other fields apply. 

Protocol specific 

A requirement that is defined by a SCSI transport protocol standard. A detailed definition of protocol spe¬ 
cific may be found in SAM-3. 

Protocol standard 

A SCSI standard that defines SCSI transport protocol (e.g., SAS, SPI-5, SBP-3, or FCP-2). 

Proxy token 

An identifier for a logical unit that may be used to gain temporary access to that logical unit in the presence 
of access controls. 

Redundancy group 

A grouping of XOR-protected data and associated check data into a single type of data redundancy (see 
SCC-2). the standard only supports the XOR type of redundancy. 

Request for comment (RFC) 

The name given to standards developed by the Internet Engineering Task Force. 

Registered 

The condition that exists for an I T nexus following the successful completion of a PERSISTENT 
RESERVE OUT command with a REGISTER service action, REGISTER AND IGNORE EXISTING KEY 
service action, or REGISTER AND MOVE service action and lasting until the registration is removed. 

Registrant 

An l_T nexus that is registered. 

Right-aligned 

A type of field containing ASCII data in which unused bytes are placed at the start of the field (i.e., lowest 
offset) and are filled with ASCII space (20h) characters. 
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Relative port identifier 

An identifier for a SCSI port that is unique within a SCSI device. Application clients may use the SCSI Ports 
VPD page to determine relative port identifier values. 

Relative initiator port identifier 

A relative port identifier for a SCSI initiator port. 

Relative target port identifier 

A relative port identifier for a SCSI target port. 

SCSI device 

A device that contains one or more SCSI ports that are connected to a service delivery subsystem and 
supports a SCSI application protocol. 

SCSI device name 

A name of a SCSI device that is world wide unique within the protocol of a SCSI domain in which the SCSI 
device has SCSI ports. The SCSI device name may be made available to other SCSI devices or SCSI 
ports in protocol specific ways. 

SCSI domain 

The interconnection of two or more SCSI devices and a service delivery subsystem. A detailed definition of 
a SCSI Domain may be found in SAM-3. 

SCSI initiator device 

A SCSI device containing application clients and SCSI initiator ports that originate device service and task 
management requests to be processed by a SCSI target device and receives device service and task man¬ 
agement responses from SCSI target devices. 

SCSI initiator port 

A SCSI initiator device object acts as the connection between application clients and the service delivery 
subsystem through which requests and responses are routed. 

SCSI port 

A port of a SCSI device that connects the application client, device server or task manager to the service 
delivery subsystem. 

SCSI port identifier 

A value by which a SCSI port is referenced within a domain. The SCSI port identifier is either an initiator 
port identifier or a target port identifier. 

SCSI port name 

A name of a SCSI port that is world wide unique within the protocol of the SCSI domain of that SCSI port. 
The name may be made available to other SCSI devices or SCSI ports in that SCSI domain in protocol 
specific ways. 

SCSI Ports VPD page 

A VPD page that allows retrieval of information about all the SCSI ports in a SCSI target device or SCSI 
target/initiator device. 

SCSI target device 

A SCSI device containing logical units and SCSI target ports that receives device service and task man¬ 
agement requests for processing and sends device service and task management responses to SCSI initi¬ 
ator devices. 

SCSI target port 

A SCSI target device object that acts as the connection between device servers and task managers and 
the service delivery subsystem through which requests and responses are routed. 

SCSI transport protocol standard 

A SCSI standard that defines a SCSI transport protocol (e.g., FCP-2, SAS, SRP, or SBP-3). 


SCSI Commands Reference Manual, Rev. A 



Sense data 

Data describing an error or exceptional condition that a device server delivers to an application client in the 
same l_T_L_Q nexus transaction as a CHECK CONDITION status or in response to a REQUEST SENSE 
command. The format of sense data is defined in SPC-4. 

Sense key 

The contents of the sense key field in the sense data. 

Service action 

A request describing a unit of work to be performed by a device server. A service action is an extension of 
a command. 

Service delivery subsystem 

That part of a SCSI I/O system that transmits service requests to a logical unit or SCSI target device and 
returns logical unit or SCSI target device responses to a SCSI initiator device. 

Standby power condition 

When a device server is capable of accepting commands, but not capable of processing media access 
commands. 

Status 

One byte of response information sent from a device server to an application client upon completion of 
each command. 

Storage array controller 

Any combination of an initiator and application clients (see SAM-3) that originates SCSI commands, con¬ 
verts input LUNs to output LUNs, and converts input LBAs to output LBAs. A storage array controller orga¬ 
nizes a group of direct-access block devices into various objects (e.g., redundancy groups and volume 
sets). See SCC-2. 

System 

One or more SCSI domains operating as a single configuration. 

Target device name 

A SCSI device name of a SCSI target device or of a SCSI target/initiator device when operating as a SCSI 
target device. 

Target port 

Synonymous with SCSI target port. 

Target port asymmetric access state 

The characteristic that defines the behavior of a target port and the allowable command set for a logical 
unit when commands and task management functions are routed through the target port maintaining that 
state. 

Target port group 

A set of target ports that are in the same target port asymmetric access state at all times. 

Target port group asymmetric access state 

The target port asymmetric access state common to the set of target ports in a target port group. 

Target port identifier 

A value by which a SCSI target port is referenced within a SCSI domain. 

Target port name 

A SCSI port name of a SCSI target port or of a SCSI target/initiator port when operating as a SCSI target 
port. 
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Task 

An object within a logical unit that represents the work associated with a command or a group of linked 
commands. A detailed definition of a task may be found in SAM-3. 

Task set 

A group of tasks within a logical unit, whose interaction is dependent on the task management (queuing) 
and ACA rules. See SAM-3 and the Control mode page. 

TCP port numbers 

One of the data needed to establish a TCP connection. TCP port numbers may be assigned to protocols 
that layer on TCP by the Internet Assigned Numbers Authority. The Internet Assigned Numbers Authority 
maintains a list of TCP port number assignments at http://www.iana.org/assignments/ port-numbers. 

Third-party command 

A command sent to one SCSI device requesting than an operation be performed involving two other SCSI 
devices (e.g., the EXTENDED COPY command may perform copy operations between two or more SCSI 
devices none of which are the SCSI device to which the EXTENDED COPY command was sent). 

Unit attention condition 

A state that a logical unit maintains while it has asynchronous status information to report to the initiator 
ports associated with one or more l_T nexuses. See SAM-3. 

Universal time (UT) 

The time at longitude zero, colloquially known as Greenwich Mean Time. See http://aa.usno.navy.mil/faq/ 
docs/UT.html. 

URI Schemes 

The Internet Assigned Numbers Authority maintains a list of schemes for URI and URL names at http:// 
www.iana.org/assignments/uri-schemes. 

User data 

Data contained in logical blocks that is not protection information. 

UTF-8 

A character set that is a transformation format of the character set defined by ISO 10646. See RFC 2279. 

Vendor specific (VS) 

Something (e.g., a bit, field, or code value) that is not defined by the standard and may be vendor defined. 

Volatile cache memory or Volatile cache 

Cache memory that does not retain data through power cycles. 

Volatile medium 

Medium that does not retain data written to it for a subsequent read operation through power cycles (e.g., 
a silicon memory device that loses data written to it if device power is lost). 

Well known logical unit 

A logical unit that only does specific functions. Well known logical units allow an application client to issue 
requests to receive and manage specific information usually relating to a SCSI target device. 

Well known logical unit number (W-LUN) 

The logical unit number that identifies a well known logical unit. 

XOR operation 

Performing an XOR bitwise on two identical-sized multiple-bit input values (e.g., the current value of a log¬ 
ical block and the new value for that logical block). In a storage array implementing a redundancy group, 
the XOR operation is used in error correction algorithms and may be performed by the storage array con¬ 
troller or by the direct-access block devices. 
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XOR-protected data 

Logical blocks, including user data and protection information, if any, that are part of a redundancy group. 

Zero 

The logical false condition of a variable. 

Zero-padded 

A type of field in which unused bytes are placed at the end of the field (i.e., highest offset) and are filled 
with zeros. 

1.2 Symbols and abbreviations 

See Table 1 for abbreviations of standards bodies (e.g., ISO). Additional symbols and abbreviations used 
in the manual include: 

Abbreviation Meaning 

< less than 

> greater than 

ACE Access Control list Entry 

ACL Access Control List 

ACA Auto Contingent Allegiance 

ADC Automation/Drive Interface - Commands 

ADT Automation/Drive Interface - Transport Protocol 

ASC Additional Sense Code 

ASCII American Standard Code for Information Interchange 

ASCQ Additional Sense Code Qualifier 

ATA AT Attachment (see www.t13.org) 

ATAPI AT Attachment with Packet Interface (see www.t13.org) 

CDB Command Descriptor Block 

CRC Cyclic Redundancy Check 

CLIST logical unit certification list 

D ID Destination Identifier (defined in FC-FS) 

DLIST data defect list 

ECC error correcting code 

EUI-48 Extended Unique Identifier, a 48-bit globally unique identifier 

EUI-64 Extended Unique Identifier, a 64-bit globally unique identifier 

FC-FS Fibre Channel Framing and Signaling Interface 
FCP-2 Fibre Channel Protocol for SCSI -2 
GLIST grown defect list 

HTTP Hypertext Transfer Protocol (see RFC 2616) 

I/O input/output 

ID Identifier or Identification 

IEC International Electrotechnical Commission 

IEEE Institute of Electrical and Electronics Engineers 

IETF Internet Engineering Task Force 

IP Internet Protocol 

IPv4 Internet Protocol version 4 

IPv6 Internet Protocol version 6 

iSCSI Internet SCSI 

ISO Organization for International Standards 

LBA Logical Block Address 
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LSB Least Significant Bit 

LUACD Logical Unit Access Control Descriptor 

LUN Logical Unit Number 

MAM Medium Auxiliary Memory 

MMC-4 SCSI Multi-Media Commands -4 

MSB Most Significant Bit 

NAA Network Address Authority 

n/a not applicable 

INCUS InterNational Committee for Information Technology Standards 

OCRW SCSI Specification for Optical Card Reader/Writer 

OSD Object-based Storage Devices Commands 

OUI Organizationally Unique Identifier 

PLIST primary defect list 

RAID Redundant Array of Independent Disks 

RBC SCSI Reduced Block Commands 

RDMA Remote Direct Memory Access (see SRP) 

RFC Request For Comments 

RMC SCSI Reduced Multi-Media Commands 

SAM-2 SCSI Architecture Model -2 

SAM-3 SCSI Architecture Model -3 

SAM-4 SCSI Architecture Model -4 

SAT SCSI / ATA Translation 

SBC-2 SCSI Block Commands -2 

SBC-3 SCSI Block Commands -3 

SBP-3 Serial Bus Protocol -3 

SCC-2 SCSI Controller Commands -2 

SCC-3 SCSI Controller Commands -3 

SCSI The architecture defined by the family of standards described in clause 1 

SES SCSI-3 Enclosure Services 

SES-2 SCSI Enclosure Services -2 

SMC-2 SCSI Media Changer Commands -2 

SMC-3 SCSI Media Changer Commands -3 

SPC SCSI-3 Primary Commands (ANSI INCITS 301-1997) 

SPC-2 SCSI Primary Commands -2 

SPC-3 SCSI Block Commands - 3 

SPC-4 SCSI Primary Commands -4 

SPI-5 SCSI Parallel Interface -5 

SRP SCSI RDMA Protocol 

SSC-2 SCSI Stream Commands -2 

TCP Transmission Control Protocol (see RFC 793) 

URI Uniform Resource Identifier (see RFC 2396 and RFC 3305) 

URL Uniform Resource Locator (see RFC 2396 and RFC 3305) 

UT Universal time 

USB Universal Serial Bus (see www.usb.org) 

VPD Vital Product Data 

VS Vendor Specific 

W-LUN Well known logical unit number 
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1.3 Keywords 

Expected 

A keyword used to describe the behavior of the hardware or software in the design models assumed by the 
standard. Other hardware and software design models may also be implemented. 

Ignored 

A keyword used to describe an unused bit, byte, word, field or code value. The contents or value of an 
ignored bit, byte, word, field or code value shall not be examined by the receiving SCSI device and may be 
set to any value by the transmitting SCSI device. 

Invalid 

A keyword used to describe an illegal or unsupported bit, byte, word, field or code value. Receipt of an 
invalid bit, byte, word, field or code value shall be reported as an error. 

Mandatory 

A keyword indicating an item that is required to be implemented as defined in this 
standard. 

May 

A keyword that indicates flexibility of choice with no implied preference (equivalent to “may or may not”). 

May not 

Keywords that indicate flexibility of choice with no implied preference (equivalent to “may or may not”). 

Need not 

Keywords indicating a feature that is not required to be implemented (equivalent to “is not required to”). 

Obsolete 

A keyword indicating that an item was defined in prior SCSI standards but has been removed from the 
standard. 

Optional 

A keyword that describes features that are not required to be implemented by the standard. However, if 
any optional feature defined in the standard is implemented, then it shall be implemented as defined in the 
standard. 

Reserved 

A keyword referring to bits, bytes, words, fields and code values that are set aside for future standardiza¬ 
tion. A reserved bit, byte, word or field shall be set to zero, or in accordance with a future extension to the 
standard. Recipients are not required to check reserved bits, bytes, words or fields for zero values. Receipt 
of reserved code values in defined fields shall be reported as an error. 

Restricted 

A keyword referring to bits, bytes, words, and fields that are set aside for use in other SCSI standards. A 
restricted bit, byte, word, or field shall be treated as a reserved bit, byte, word or field for the purposes of 
the requirements defined in the standard. 

Shall 

A keyword indicating a mandatory requirement. Designers are required to implement all such mandatory 
requirements to ensure interoperability with other products that conform to the standard. 

Should 

A keyword indicating flexibility of choice with a strongly preferred alternative; equivalent to the phrase “it is 
strongly recommended.” 

Vendor-specific 

Something (e.g., a bit, field, or code value) that is not defined by the standard and may be used differently 
in various implementations. 
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1.4 


Conventions 


Certain words and terms used in the standard have a specific meaning beyond the normal English meaning. 
These words and terms are defined either in this clause or in the text where they first appear. Names of com¬ 
mands, status codes, sense keys, and additional sense codes are in all uppercase (e.g., REQUEST SENSE). 

If there is more than one CDB length for a particular command (e.g., MODE SENSE(6) and MODE 
SENSE(IO)) and the name of the command is used in a sentence without any CDB length descriptor (e.g., 
MODE SENSE), then the condition specified in the sentence applies to all CDB lengths for that command. 

Names of fields and state variables are in uppercase (e.g. NAME). When a field or state variable name con¬ 
tains acronyms, uppercase letters may be used for readability. Normal case is used when the contents of a 
field or state variable are being discussed. Fields or state variables containing only one bit are usually referred 
to as the NAME bit instead of the NAME field. 

Normal case is used for words having the normal English meaning. 

A binary number is represented in the standard by any sequence of digits comprised of only the Western-Ara- 
bic numerals 0 and 1 immediately followed by a lower-case b (e.g., 0101b). Underscores or spaces may be 
included between characters in binary number representations to increase readability or delineate field bound¬ 
aries (e.g., 0 0101 1010b or 0_0101_1010b). 

A hexadecimal number is represented in the standard by any sequence of digits comprised of only the West- 
ern-Arabic numerals 0 through 9 and/or the upper-case English letters A through F immediately followed by a 
lower-case h (e.g., FA23h). Underscores or spaces may be included in hexadecimal number representations to 
increase readability or delineate field boundaries (e.g., B FD8CFA23h or B_FD8C_FA23h). 

A decimal number is represented in the standard by any sequence of digits comprised of only the Western-Ara- 
bic numerals 0 through 9 not immediately followed by a lower-case b or lower-case h (e.g., 25). 

When the value of the bit or field is not relevant, x or xx appears in place of a specific value. 

the standard uses the ISO convention for representing decimal numbers (e.g., the thousands and higher multi¬ 
ples are separated by a space and a comma is used as the decimal point). Table 1 shows some examples of 
decimal numbers represented using the ISO and American conventions. 

Table 1 — ISO v American Numbering Conventions 


ISO 

American 

0,6 

0.6 

3,141 592 65 

3.14159265 

1 000 

1,000 

1 323 462 

1,323,462.95 


Lists sequenced by letters (e.g., a) red, b) blue, c) green) show no ordering relationship between the listed 
items. Lists sequenced by numbers (e.g., 1) red, 2) blue, 3) green) show an ordering relationship between the 
listed items. 

If a conflict arises between text, tables or figures, the order of precedence to resolve the conflicts is text, then 
tables, and finally figures. Not all tables or figures are fully described in the text. Tables show data format and 
values. Notes do not constitute any requirements for implementors. 
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2.0 General Concepts 


This manual defines behaviors that are common to all Seagate SCSI device models. This manual defines the 
SCSI commands that are basic to more than one disc drive model and the SCSI commands that may apply to 
any SCSI Interface, including Parallel, Fibre Channel, and Serial Attached SCSI (SAS). 
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2.1 


Command Descriptor Block (CDB) 


2.1.1 CDB usage and structure 

A command is communicated by sending a command descriptor block (CDB) to the device server. For several 
commands, the CDB is accompanied by a list of parameters in the Data-Out Buffer. See the specific com¬ 
mands for detailed information. 

If a logical unit validates reserved CDB fields and receives a reserved field within the CDB that is not zero, then 
the logical unit shall terminate the command with CFIECK CONDITION status, with the sense key set to ILLE¬ 
GAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 

If a logical unit receives a reserved CDB code value in a field other than the OPERATION CODE field, then the 
logical unit shall terminate the command with CFIECK CONDITION status, with the sense key set to ILLEGAL 
REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 

The fixed length CDB formats are described in 2.1.2. The variable length CDB formats are described in 2.1.4. 
The CDB fields that are common to most commands are described in 2.1.5. The fields shown in 2.1.2 and 
2.1.3 and described in 2.1.4 are used consistently by most commands. Flowever, the actual usage of any field 
(except OPERATION CODE and CONTROL) is described in the subclause defining that command. If a device 
server receives a CDB containing an operation code that is invalid or not supported, the command shall be ter¬ 
minated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional 
sense code set to INVALID COMMAND OPERATION CODE. 

For all commands, if there is an invalid parameter in the CDB, the device server shall terminate the command 
without altering the medium. 

2.1.2 The fixed length CDB formats 

All fixed length CDBs shall have an OPERATION CODE field as their first byte and a CONTROL byte as their last byte. 
Table 2 shows the typical format of a 6-byte CDB. Table 3 shows the typical format of a 10-byte CDB. Table 4 shows the 
typical format of a 12-byte CDB. Table 5 shows the typical format of a 16-byte CDB. Table 6 shows the format of a 16-byte 
CDB for commands that provide for a long LBA. 


Table 2 — Typical CDB for 6-byte commands 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE 

1 

Miscellaneous CDB information (MSB) 

2 

LOGICAL BLOCK ADDRESS (if required) 

3 

(LSB) 

4 

TRANSFER LENGTH (if required) 

PARAMETER LIST LENGTH (if required) 

ALLOCATION LENGTH (if required) 

5 

CONTROL 
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Table 3 — Typical CDB for 10-byte commands 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE 

1 

Miscellaneous CDB information SERVICE ACTION (if required) 

2 

(MSB) LOGICAL BLOCK ADDRESS (if required) 

3 


4 

5 

(LSB) 

6 

Miscellaneous CDB information 

7 

(MSB) TRANSFER LENGTH (if required) 

8 

PARAMETER LIST LENGTH (if required) 

ALLOCATION LENGTH (if required) (LSB) 

9 

CONTROL 


Table 4 — Typical CDB for 12-byte commands 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE 

1 

Miscellaneous CDB information SERVICE ACTION (if required) 

2 

(MSB) LOGICAL BLOCK ADDRESS (if required) 

3 


4 

5 

(LSB) 

6 

(MSB) TRANSFER LENGTH (If required) 

7 

PARAMETER LIST LENGTH (if required) 

ALLOCATION LENGTH (if required) 

8 

9 

(LSB) 

10 

Miscellaneous CDB information 

11 

CONTROL 
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Table 5 — Typical CDB for 16-byte commands 


Bit 

Byte 

7 6 5 4 3 2 1 

0 

OPERATION CODE 

1 

Miscellaneous CDB information SERVICE ACTION (if required)] 

2 

(MSB) LOGICAL BLOCK ADDRESS (if required) 

3 

- 

4 

5 

6 

(MSB) Additional CDB data (if required) 

7 

- 

8 

9 

10 

(MSB) TRANSFER LENGTH (If required) 

11 

PARAMETER LIST LENGTH (if required) 

ALLOCATION LENGTH (if required) 

12 

13 

14 

Miscellaneous CDB information 

15 

CONTROL 
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Table 6 — Typical CDB for long LB A 16-byte commands 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE 

1 

Miscellaneous CDB information 

2 

(MSB) 

3 

LOGICAL BLOCK ADDRESS 

4 

5 

6 

7 

8 

9 

(LSB) 

10 

(MSB) TRANSFER LENGTH (If required) 

11 

PARAMETER LIST LENGTH (if required) 

ALLOCATION LENGTH (if required) 

12 

13 

(LSB) 

14 

Miscellaneous CDB information 

15 

Control 
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2.1.3 The variable length CDB formats 

The first byte of a variable length CDB shall contain the operation code 7Fh. The CONTROL byte is the second 
byte in the variable length CDB (see table 7) 

Table 7 — Typical variable length CDB 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (7Fh) 

1 

CONTROL 

2 

Miscellaneous CDB information 

3 

Miscellaneous CDB information 

4 

Miscellaneous CDB information 

5 

Miscellaneous CDB information 

6 

Miscellaneous CDB information 

7 

ADDITIONAL CDB LENGTH (n-7) 

8 

(MSB) SERVICE ACTION 

9 

(LSB) 

10 

Service Action specific fields 


ADDITIONAL CDB LENGTH field 

The ADDITIONAL CDB LENGTH field specifies the number of additional CDB bytes. This value in the ADDITIONAL CDB 
LENGTH field shall be a multiple of 4. If the number of CDB bytes delivered by the service delivery subsystem is not suffi¬ 
cient to contain the number of bytes specified by the ADDITIONAL CDB LENGTH field, then the command shall be termi¬ 
nated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to 
INVALID FIELD IN CDB. 

SERVICE ACTION field 

The SERVICE ACTION field specifies the action being requested by the application client. The SERVICE ACTION field is 
required in the variable length CDB format and is described in 4.3.4.2. Each service action code description defines a num¬ 
ber of service action specific fields that are needed for that service action. 

A 32-byte variable length CDB format is defined for long LBA operations (see table 8) 
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Table 8 — Typical variable length CDB for long LBA 32-byte commands 


Bit 

Byte 

7 

6 5 4 3 2 1 

0 

0 

OPERATION CODE (7Fh) 

1 

CONTROL 

2 

Miscellaneous CDB information 

3 

Miscellaneous CDB information 

4 

Miscellaneous CDB information 

5 

Miscellaneous CDB information 

6 

Miscellaneous CDB information 

7 

Additional CDB Length (n-7) [9] 

8 

(MSB) 

SERVICE ACTION 


9 


(LSB) 

10 

Miscellaneous CDB information | DPO | FUA | Miscellaneous CDB information 

11 

Miscellaneous CDB information 

12 

(MSB) 

LOGICAL BLOCK ADDRESS 


19 


(LSB) 

20 

Miscellaneous CDB information 

27 

28 

(MSB) 

TRANSFER LENGTH (If required) 

PARAMETER LIST LENGTH (if required) 

ALLOCATION LENGTH (if required) 


31 


(LSB) 
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2.2 


Common CDB fields 


2.2.1 Operation Code 

The first byte of a SCSI CDB shall contain an operation code identifying the operation being requested by the CDB. Some 
operation codes provide for modification of their operation based on a service action (see 2.1.4.2). In such cases, the oper¬ 
ation code and service action code combine to identify the operation being requested. The location of the SERVICE 
ACTION field in the CDB varies depending on the operation code value. 

The OPERATION CODE (see table 10) of the CDB has a GROUP CODE field and a COMMAND CODE field. The three-bit 
GROUP CODE field provides for eight groups of command codes. The five-bit COMMAND CODE field provides for thirty- 
two command codes in each group. A total of 256 possible operation codes exist. Operation codes are defined in the stan¬ 
dard and other command standards. The group code value shall determine the length of the CDB (see table 11). 


Table 9 — OPERATION CODE byte 


GROUP CODE 


COMMAND CODE 


The value in the GROUP CODE field specifies one of the groups shown in Table 10. 

Table 10 — Group Code values 


Group 

Code 

Meaning 

Typical CDB Format 

000b 

6 byte commands 

see Table 2 

001b 

10 byte commands 

see Table 3 

010b 

10 byte commands 

see Table 3 

011b 

Reserved a 


100b 

16 byte commands 

see Table 5 and Table 6 

101b 

12 byte commands 

see Table 4 

110b 

Vendor Specific 


111b 

Vendor Specific 


a The format of the commands using operation code 7Fh is described 
in 2.1.3. With the exception of operation code 7Fh, all group code 
011b operation codes are reserved. 


2.2.2 Service action 

All CDB formats except the 6-byte format provide for a SERVICE ACTION field containing a coded value iden¬ 
tifying a function to be performed under the more general command function specified in the OPERATION 
CODE field. While the SERVICE ACTION field is defined for CDB formats, it is used as described in this sub¬ 
clause only in those CDB formats that contain a SERVICE ACTION field. When the specific field SERVICE 
ACTION is not defined in a CDB format, the bits identified as the SERVICE ACTION field in a CDB shall be 
used or reserved as specified by the particular CDB format. 

2.2.3 Logical block address 

The logical block addresses on a logical unit or within a volume or partition shall begin with block zero and be 
contiguous up to the last logical block of that logical unit or within that volume or partition. 
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A six-byte CDB may contain a 21-bit LOGICAL BLOCK ADDRESS field. The ten-byte and the twelve-byte 
CDBs may contain 32-bit LOGICAL BLOCK ADDRESS fields. The sixteen-byte CDB has two formats: one 
allows a 32-bit LOGICAL BLOCK ADDRESS field (see Table 5) and the other allows a 64-bit LOGICAL BLOCK 
ADDRESS field (see Table 6). LOGICAL BLOCK ADDRESS fields in additional parameter data have their 
length specified for each occurrence. See the specific command descriptions. 

2.2.4 Transfer length 

The TRANSFER LENGTH field specifies the amount of data to be transferred, usually the number of blocks. 
Some commands use transfer length to specify the requested number of bytes to be sent as defined in the 
command description. 

Commands that use one byte for the TRANSFER LENGTH field may allow up to 256 blocks or 256 bytes of 
data to be transferred by one command. 

In commands that use multiple bytes for the TRANSFER LENGTH field, a transfer length of zero specifies that 
no data transfer shall take place. A value of one or greater specifies the number of blocks or bytes that shall be 
transferred. Refer to the specific command description for further information. 

2.2.5 Parameter list length 

The PARAMETER LIST LENGTH field is used to specify the number of bytes sent from the Data-Out Buffer. 
This field is typically used in CDBs for parameters that are sent to a device server (e.g., mode parameters, 
diagnostic parameters, log parameters). A parameter length of zero specifies that no data shall be transferred. 
This condition shall not be considered as an error, unless otherwise specified. 

2.2.6 Allocation length 

The ALLOCATION LENGTH field specifies the maximum number of bytes that an application client has allo¬ 
cated in the Data-In Buffer. An allocation length of zero specifies that no data shall be transferred. This condi¬ 
tion shall not be considered as an error. The device server shall terminate transfers to the Data-In Buffer when 
the number of bytes specified by the ALLOCATION LENGTH field have been transferred or when all available 
data have been transferred, whichever is less. The allocation length is used to limit the maximum amount of 
variable length data (e.g., mode data, log data, diagnostic data) returned to an application client. If the informa¬ 
tion being transferred to the Data-In Buffer includes fields containing counts of the number of bytes in some or 
all of the data, then the contents of these fields shall not be altered to reflect the truncation, if any, that results 
from an insufficient ALLOCATION LENGTH value, unless the standard that describes the Data-In Buffer format 
states otherwise. 

If the amount of information to be transferred exceeds the maximum value that the ALLOCATION LENGTH 
field is capable of specifying, the device server shall transfer no data and terminate the command with CHECK 
CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to 
INVALID FIELD IN CDB. 
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2.2.7 


Control 


The contents of the CONTROL byte are defined in SAM-4. The CONTROL byte has the same definition for all 
commands. 

SAM-4 clause 5.2 states: 

All CDBs shall contain a CONTROL byte (see table 11). The location of the CONTROL byte within a CDB 
depends on the CDB format (see 2.1.2 and 2.1.3). 

Table 11 — Control Byte 


Bit 

7 6 

5 

i 4 r 

3 

2 

1 

0 


Vendor Specific 

Reserved 

NACA 

Obsolete [1] 

LINK 


[1] Bit 1 of the Control byte was formerly the Flag bit See Flag bit below). 

All SCSI transport protocol standards shall define the functionality needed for a logical unit to implement the 

NACA bit and LINK bit. 

NACA (Normal ACA) bit 

The NACA (Normal ACA) bit specifies whether an auto contingent allegiance (ACA) is established if the command returns 

with CHECK CONDITION status. An NACA bit set to one specifies that an ACA shall be established. 

0 An NACA bit set to zero specifies that an ACA shall not be established. The actions for ACA are specified in SAM-4 
clause 5.8.2. Actions that may be required when an ACA is not established are described in SAM-4 clause 5.8.1. All 
logical units shall implement support for the NACA value of zero and may support the NACA value of one (i.e., 
ACA). The ability to support a NACA value of one is indicated with the NORMACA bit in the standard INQUIRY data 
(see SPC-4). 

1 If the NACA bit is set to one but the logical unit does not support ACA, the command shall be terminated with 
CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to 
INVALID FIELD IN CDB. 

LINK bit 

The LINK bit is used to continue the task across multiple commands. Support for the LINK bit is optional. The application 

client sets the LINK bit to one to specify a request for continuation of the task across two or more commands. 

1 If the LINK bit is set to one and the command completes successfully, a logical unit that supports the LINK bit shall 
continue the task and return a status of INTERMEDIATE or INTERMEDIATE-CONDITION MET and a service 
response of LINKED COMMAND COMPLETE (see SAM-4). If the LINK bit is set to one and the logical unit does not 
support linked commands, the command shall be terminated with CHECK CONDITION status, with the sense key 
set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB.D FIELD IN CDB. 

FLAG bit -- declared Obsolete by T10 

Bit 1 (formerly the flag bit) was made obsolete prior to the release of SAM-2 in September of 2002. 

Note. In older model drives the Flag bit may have been used in conjunction with the Link bit to notify the 
initiator in an expedited manner that the command has completed. 

Support for the Flag bit is a logical unit option. If the Link bit and Flag bit are both set to one, and if the 
command completes with a status of Intermediate or Intermediate-Condition Met, a drive that supports the 
Flag bit returns a service response of Linked Command Complete (with Flag). 

The drive completes the command with a status of Check Condition and a sense key of Illegal Request if: 

[a] • The Link bit is set to one and the drive does not support linked commands, or 

[b] • The Flag bit is set to one and the drive does not support the Flag bit, or 

[c] • The Flag bit is set to one and the Link bit is set to zero. 
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2.2.8 Grouping function 

A grouping function is a function that collects information about attributes associated with commands (i.e., 
information about commands with the same group value are collected into the specified group). The definition 
of the attributes and the groups is outside the scope of this standard. Groups are identified with the GROUP 
NUMBER field in the CDB of certain commands (e.g., the WRITE (10) command (see 3.54)). 

The collection of this information is outside the scope of this standard (e.g., the information may not be trans¬ 
mitted using any SCSI protocols). 

Note. An example of how grouping could be used, consider two applications using a subsystem; one 
application streams data and another accesses data randomly. If the streaming application groups 
all of its commands with one value (e.g., x), and the random application groups all of its commands 
with another value (e.g., y), then a group x defined to hold performance metrics collects all the per¬ 
formance metrics for the streamed commands together and a group y defined to also hold perfor¬ 
mance metrics collects all the performance metrics for the random commands together. The result 
is two sets of performance metrics (i.e., x and y). A management application then reads the perfor¬ 
mance metrics and determines if the performance of a specific group is acceptable. 

Support for the grouping function is indicated in the GROUP_SUP bit in the Extended INQUIRY Data VPD page 
(see SPC-4). 
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2.3 Parameter rounding 

Certain parameters sent to a SCSI target port with various commands contain a range of values. Targets may 
choose to implement only selected values from this range. When the target receives a value that it does not 
support, it either rejects the command (CHECK CONDITION status with Illegal Request Sense key) or it 
rounds the value received to a supported value. The target shall reject unsupported values unless rounding is 
permitted in the description of the parameter. 

Rounding of parameter values, when permitted (Rounding is enabled by MODE SELECT command, page 
code OOh, byte 2, bit 2) shall be performed as follows: 

a SCSI target port that receives a parameter value that is not an exact supported value shall adjust the value to 
one that it supports and shall return CHECK CONDITION status with a sense key of Recovered Error. The 
additional sense code shall be set to Rounded Parameter. The initiator is responsible to issue an appropriate 
command to learn what value the target has selected. 

Implementor’s Note: Generally, the target should adjust maximum-value fields down to the next lower sup¬ 
ported value than the one specified by the initiator. Minimum-value fields should be rounded up to the next 
higher supported value than the one specified by the initiator. In some cases, the type of rounding (up or down) 
is explicitly specified in the description of the parameter. 
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2.4 


Sense data 


2.4.1 Sense data introduction 

Sense data shall be returned in the same l_T_L_Q nexus transaction as a CHECK CONDITION status and as 
parameter data in response to the REQUEST SENSE command. Sense data returned in the same l_T_L_Q 
nexus transaction as a CHECK CONDITION status shall be either fixed or descriptor format sense data format 
based on the value of the D SENSE bit in the Control mode page. The REQUEST SENSE command may be 
used to request either the fixed format sense data or the descriptor format sense data.f 

The first byte of all sense data contains the RESPONSE CODE field that indicates the error type and format of 
the sense data (see table 12). 


Table 12 — Sense data response codes 


Response 

Code 

Error type 

Sense data format 

Description Reference 

Description Reference 

OOh - 6Fh 

Reserved 

70h 

Current 

2.4.1.3 

Fixed 

2.4.1.2 

71 h 

Deferred 

2.4.1.4 

Fixed 

2.4.1.2 

72h 

Current 

2.4.1.3 

Descriptor 

2.4.1.1 

73h 

Deferred 

2.4.1.4 

Descriptor 

2.4.1.1 

74h - 7Eh 

Reserved 

7Fh 

Vendor specific 


The RESPONSE CODE field shall be set to 70h in all unit attention sense data in which: 

a) The ADDITIONAL SENSE CODE field is set to 29h; or 

b) The additional sense code is set to MODE PARAMETERS CHANGED. 
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2.4.1.1 Descriptor format sense data 


2.4.1.1.1 Descriptor format sense data overview 

The descriptor format sense data for response codes 72h (current errors) and 73h (deferred errors) is defined 
in table 13. 

Table 13 — Descriptor format sense data 


Bit 

Byte 

7 

6 5 4 3 2 1 0 

0 

Reserved 

RESPONSE CODE (72h or 73h) 

1 

Reserved SENSE KEY 

2 

ADDITIONAL SENSE CODE 

3 

ADDITIONAL SENSE CODE QUALIFIER 

4 


5 

Reserved 

6 


7 

ADDITIONAL SENSE LENGTH (n-7) 


Sense Data Descriptor(s) 


8 





SENSE DATA DESCRIPTOR 0 (see table 14) 



n 

SENSE DATA DESCRIPTOR X (see table 14) 


RESPONSE CODE field 

The contents of the RESPONSE CODE field indicate the error type and format of the sense data (see 2.4.1). For descriptor 
format sense data, the RESPONSE CODE field shall be set to 72h or 73h. 

SENSE KEY, ADDITIONAL SENSE CODE and ADDITIONAL SENSE CODE QUALIFIER fields 

The SENSE KEY, ADDITIONAL SENSE CODE and ADDITIONAL SENSE CODE QUALIFIER fields provide a hierarchy of 
information. The hierarchy provides a top-down approach for an application client to determine information relating to the 
error and exception conditions. 

SENSE KEY field 

The SENSE KEY field indicates generic information describing an error or exception condition. The sense keys are defined 
in 2.4.1.5. 

ASC (ADDITIONAL SENSE CODE) field 

The ADDITIONAL SENSE CODE (ASC) field indicates further information related to the error or exception condition 
reported in the SENSE KEY field. Support of the additional sense codes not required by this standard is optional. A list of 
additional sense codes is in 2.4.1.5. If the device server does not have further information related to the error or exception 
condition, the additional sense code shall be set to zero. 
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ASCQ (ADDITIONAL SENSE CODE QUALIFIER) field 

The ADDITIONAL SENSE CODE QUALIFIER (ASCQ) field indicates detailed information related to the additional sense 
code. If the error or exception condition is reported by the device server, the value returned shall be as specified in 2.4.1.5. 
If the device server does not have detailed information related to the error or exception condition, the additional sense code 
qualifier shall be set to zero. 

ADDITIONAL SENSE LENGTH field 

The ADDITIONAL SENSE LENGTH field indicates the number of additional sense bytes that follow. The additional sense 
length shall be less than or equal to 244 (i.e., limiting the total length of the sense data to 252 bytes). If the sense data is 
being returned as parameter data by a REQUEST SENSE command, then the relationship between the ADDITIONAL 
SENSE LENGTH field and the CDB ALLOCATION LENGTH field is defined in 2.4.1.1.1. 

SENSE DATA DESCRIPTORS field 

Sense data descriptors (see table 14) provide specific sense information. A given type of sense data descriptor shall be 
included in the sense data only when the information it contains is valid. 


Table 14 — Sense data descriptor format 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

DESCRIPTOR TYPE 

1 

ADDITIONAL LENGTH (n-1) 

2 

SENSE DATA DESCRIPTOR SPECIFIC 

n 



DESCRIPTOR TYPE field 

The DESCRIPTOR TYPE field contains a type code (see table 15) that identifies the type of sense data descriptor. No 
more than one sense data descriptor of each type shall be included in the descriptor format sense data. 


Table 15 — Sense data descriptor types 


Type 

Description 

Reference 

OOh 

Information 

2.4.1.1.2 

01 h 

Command specific information 

2.4.1.1.3 

02h 

Sense key specific 

2.4.1.1.4 

03h 

Field replaceable unit 

2.4.1.1.5 

04 h 

Stream commands 

SSC-3 

05h 

Block commands 

SBC-2 

06h 

OSD object identification 

OSD 

07h 

OSD response integrity check value 

OSD 

08h 

OSD attribute identification 

OSD 

09h 

ATA Return 

SAT 

OAh - 7Fh 

Reserved 


80h - FFh 

Vendor specific 

2.4.1.1.6 
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ADDITIONAL LENGTH field 


The ADDITIONAL LENGTH field indicates the number of sense data descriptor specific bytes that follow in the sense data 
descriptor. 

2.4.1.1.2 Information sense data descriptor 

The information sense data descriptor (see table 16) provides information that is device-type or command spe¬ 
cific and is defined in a command standard. 

Table 16 — Information sense data descriptor format 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

DESCRIPTOR TYPE (OOh) 

1 

ADDITIONAL LENGTH (OAh) 

2 

VALID (1b) Reserved 

3 

Reserved 

4 


11 

INFORMATION 


DESCRIPTOR TYPE and ADDITIONAL LENGTH fields 

The DESCRIPTOR TYPE and ADDITIONAL LENGTH fields are described in 2.4.1.1.1. For the information sense data 

descriptor, the DESCRIPTOR TYPE field shall be set to OOh and the ADDITIONAL LENGTH field shall be set to OAh. 

The VALID bit shall be set to one. 

Note. In previous versions of this standard and in the fixed format sense data, the VALID bit indicates 
whether the contents of the INFORMATION field is valid as defined by a command standard. Since 
the contents of the INFORMATION field are valid whenever an information sense data descriptor is 
included in the sense data, the only legal value for the VALID bit is set to one. 

INFORMATION field 

The contents of the INFORMATION field are device-type or command specific and are defined in a command standard. 

When a four byte quantity is stored in the INFORMATION field, the first four bytes shall be zero. 
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2.4.1.1.3 Command-specific information sense data descriptor 

The command-specific information sense data descriptor (see table 17) provides information that depends on 
the command on which the exception condition occurred. 

Table 17 — Command-specific information sense data descriptor format 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

DESCRIPTOR TYPE (01 h) 

1 

ADDITIONAL LENGTH (OAh) 

2 

Reserved 

3 

Reserved 

4 

COMMAND-SPECIFIC INFORMATION 

11 



DESCRIPTOR TYPE and ADDITIONAL LENGTH fields 

The DESCRIPTOR TYPE and ADDITIONAL LENGTH fields are described in 2.4.1.1.1. For the command-specific informa¬ 
tion sense data descriptor, the DESCRIPTOR TYPE field shall be set to 01 h and the ADDITIONAL LENGTH field shall be 
set to OAh. 

COMMAND-SPECIFIC INFORMATION field 

The COMMAND-SPECIFIC INFORMATION field contains information that depends on the command on which the excep¬ 
tion condition occurred. When a four byte quantity is stored in the COMMAND-SPECIFIC INFORMATION field, the first four 
bytes shall be zero. 

Further meaning for the COMMAND-SPECIFIC INFORMATION field is defined within the command description in the 
appropriate command standard (e.g., see SBC-2 for the REASSIGN BLOCKS commands, or SPC-3 the EXTENDED 
COPY command). 
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2.4.1.1.4 Sense key specific sense data descriptor 

2.4.1.1.4.1 Sense key specific sense data descriptor introduction 

The sense key specific sense data descriptor (see table 18) provides additional information about the excep¬ 
tion condition. The format and content of the sense-key specific data depends on the value in the SENSE KEY 
field (see 2.4.1.1.1). 

Table 18 — Sense key specific sense data descriptor format 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

DESCRIPTOR TYPE (02h) 

1 

ADDITIONAL LENGTH (06h) 

2 

Reserved 

3 

Reserved 

4 

SKSV (1b) 

5 

SENSE KEY SPECIFIC 

6 


7 

Reserved 


The DESCRIPTOR TYPE and ADDITIONAL LENGTH fields are described in 2.4.1.1.1. For the sense-key specific sense 

data descriptor, the DESCRIPTOR TYPE field shall be set to 01 h and the ADDITIONAL LENGTH field shall be set to 06h. 

SKSV (Sense-key specific valid) bit 

The sense-key specific valid (SKSV) bit shall be set to one. 

Note. In previous versions of this standard and in the fixed format sense data, the SKSV bit indicates 
whether the contents of the SENSE KEY SPECIFIC field are valid as defined by a command stan¬ 
dard. Since the contents of the SENSE KEY SPECIFIC field are valid whenever a sense key spe¬ 
cific sense data descriptor is included in the sense data, the only legal value for the SKSV bit is set 
to one. 
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The definition of the SENSE KEY SPECIFIC field (see table 19) is determined by the value of the sense key 
field (see 2.4.1.1.1). 


Table 19 — Sense key specific field definitions 


Sense Key 

Sense Key Specific Field Definition 

Reference 

ILLEGAL REQUEST 

Field pointer 

2.4.1.1.4.2 

HARDWARE ERROR, 

MEDIUM ERROR, or 

RECOVERED ERROR 

Actual retry count 

2.4.1.1.4.3 

NO SENSE or NOT READY 

Progress indication 

2.4.1.1.4.4 

COPY ABORTED 

Segment pointer 

2.4.1.1.4.5 

All other sense keys 

The sense key specific sense data descriptor shall not appear in the descriptor for¬ 
mat sense data and the SKSV bit (see 2.4.1.2) shall be set to zero in the fixed format 
sense data. 


2.4.1.1.4.2 Field pointer sense key specific data 


If the sense key is ILLEGAL REQUEST, then the sense key specific field shall be as shown in table 20. 


Table 20 — Field pointer sense key specific data 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

SKSV (1b) 

C/D 

Reserved 

BPV 

BIT POINTER 

1 

(MSB) 








2 




FIELD POINIEK 



(LSB) 


SKSV bit 

The SKSV bit is described in 2.4.1.1.4.1 for descriptor format sense data and in 2.4.1.2 for fixed format sense data. 

C/D (Command Data) bit 

A command data (C/D) bit set to one indicates that the illegal parameter is in the CDB. A C/D bit set to zero indicates that 
the illegal parameter is in the data parameters sent by the application client in the Data-Out Buffer. 

BPV (Bit Pointer Valid) bit 

A bit pointer valid (BPV) bit set to zero indicates that the value in the BIT POINTER field is not valid. A BPV bit set to one 
indicates that the BIT POINTER field specifies which bit of the byte designated by the FIELD POINTER field is in error. 
When a multiple-bit field is in error, the BIT POINTER field shall point to the first bit (i.e., the left-most bit) of the field. 

FIELD POINTER field 

The FIELD POINTER field indicates which byte of the CDB or of the parameter data was in error. Bytes are numbered start¬ 
ing from zero, as shown in the tables describing the commands and parameters. When a multiple-byte field is in error, the 
field pointer shall point to the first byte (i.e., the left-most byte) of the field. If several consecutive bytes are reserved, each 
shall be treated as a single-byte field. 

Note. The bytes identified as being in error are not necessarily the bytes that need to be changed to cor¬ 
rect the problem. 
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2.4.1.1.4.3 


Actual retry count sense key specific data 


If the sense key is HARDWARE ERROR, MEDIUM ERROR, or RECOVERED ERROR, then the SENSE KEY 
SPECIFIC field shall be as shown in table 21. 

Table 21 — Actual retry count sense key specific data 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

SKSV (1b) 

Reserved 

1 

(MSB) 



ACTUAL RETRY COUNT 




2 








(LSB) 


The SKSV bit is described in 2.4.1.1.4.1 for descriptor format sense data and in 2.4.1.2 for fixed format sense 
data. 

The ACTUAL RETRY COUNT field returns vendor specific information on the number of retries of the recovery 
algorithm used in attempting to recover an error or exception condition. 
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Note. This field should be computed in the same way as the retry count fields within the Read-Write Error 
Recovery mode page. 

2.4.1.1.4.4 Progress indication sense key specific data 

If the sense key is NO SENSE or NOT READY, the sense key specific field shall be as shown in table 22. 

Table 22 — Progress indication sense key specific data 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

SKSV (1b) 

Reserved 

1 

(MSB) 



PROGRESS INDICATION 




2 








(LSB) 


The SKSV bit is described in 2.4.1.1.4.1 for descriptor format sense data and in 2.4.1.2 for fixed format sense 
data. 

The PROGRESS INDICATION field is a percent complete indication in which the returned value is a numerator 
that has 65 536 (lOOOOh) as its denominator. The progress indication shall be based upon the total operation. 

Note. The progress indication should be time related, however this is not an absolute requirement. (E.g., 
since format time varies with the number of defects encountered, etc., it is reasonable for the 
device server to assign values to various steps within the process. The granularity of these steps 
should be small enough to provide reasonable assurances to the application client that progress is 
being made.) 

2.4.1.1.4.5 Segment pointer sense key specific data 

If the sense key is COPY ABORTED, the SENSE KEY SPECIFIC field shall be as shown in table 23. 


Table 23 — Segment pointer sense key specific data 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

SKSV (1b) 

Reserved 

SD 

Reserved 

BPV 

BIT POINTER 

1 

(MSB) 



FIELD POINTER 




2 








(LSB) 


The SKSV bit is described in 2.4.1.1.4.1 for descriptor format sense data and in 2.4.1.2 for fixed format sense 
data. 

The segment descriptor (sd) bit indicates whether the field pointer is relative to the start of the parameter list or 
to the start of a segment descriptor. An sd bit set to zero indicates that the field pointer is relative to the start of 
the parameter list. An sd bit set to one indicates that the field pointer is relative to the start of the segment 
descriptor indicated by the third and fourth bytes of the COMMAND-SPECIFIC INFORMATION field. 

A bit pointer valid (BPV) bit set to zero indicates that the value in the BIT POINTER field is not valid. A BPV bit 
set to one indicates that the BIT POINTER field specifies which bit of the byte designated by the FIELD 
POINTER field is in error. When a multiple-bit field is in error, the BIT POINTER field shall point to the most- 
significant (i.e., left-most) bit of the field. 
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The FIELD POINTER field indicates which byte of the parameter list or segment descriptor was in error. 


If the parameter list is in excess of 65 528 bytes in length and SD is set to zero, the FIELD POINTER value 
may not fit in two bytes provided by the sense key specific sense data descriptor. 

2.4.1.1.5 Field replaceable unit sense data descriptor 

The field replaceable unit sense data descriptor (see table 24) provides information about a component that 
has failed. 

Table 24 — Field replaceable unit sense data descriptor format 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

DESCRIPTOR TYPE (03h) 

1 

ADDITIONAL LENGTH (02h) 

2 

Reserved 

3 

field replaceable unit code 


DESCRIPTOR TYPE and ADDITIONAL LENGTH fields 

The DESCRIPTOR TYPE and ADDITIONAL LENGTH fields are described in 2.4.1.1.1. For the field replaceable unit sense 
data descriptor, the DESCRIPTOR TYPE field shall be set to 03h and the ADDITIONAL LENGTH field shall be set to 02h. 

FIELD REPLACEABLE UNIT CODE field 

Non-zero values in the FIELD REPLACEABLE UNIT CODE field are used to identify a component that has failed. A value 
of zero in this field indicates that no specific component has been identified to have failed or that the data is not available. 
The format of this information is not specified by this standard. Additional information about the field replaceable unit may 
be available in the ASCII Information VPD page, if supported by the device server. 

2.4.1.1.6 Vendor specific sense data descriptors 


Vendor specific sense data descriptors (see table 25) contain vendor specific data that further defines the 
nature of the exception condition. 

Table 25 — Vendor specific sense data descriptor format 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

DESCRIPTOR TYPE (80h - FFh) 

1 

ADDITIONAL LENGTH (n-1) 

2 

Vendor specific 

n 



DESCRIPTOR TYPE and ADDITIONAL LENGTH fields 

The DESCRIPTOR TYPE and ADDITIONAL LENGTH fields are described in 2.4.1.1.1. For the vendor specific sense data 
descriptor, the DESCRIPTOR TYPE field shall be set to a value between 80h and FFh, inclusive. 
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2.4.1.2 


Fixed format sense data 


The fixed format sense data for response codes 70h (current errors) and 71 h (deferred errors) is defined in 
table 26. 

Table 26 — Fixed format sense data 


Bit 

Byte 

7 

6 5 4 3 2 1 0 

0 

VALID 

RESPONSE CODE (70H OR 71H) 

1 

Obsolete 

2 

FILEMARK EOM ILI RESERVED SENSE KEY 

3 


INFORMATION 

4 


5 

6 


7 

ADDITIONAL SENSE LENGTH (N-7) 

8 


COMMAND-SPECIFIC INFORMATION 

9 


10 

11 


12 

ADDITIONAL SENSE CODE 

13 

ADDITIONAL SENSE CODE QUALIFIER 

14 

FIELD REPLACEABLE UNIT CODE 

15 

SKSV 

SENSE KEY SPECIFIC 

16 


17 


18 


n 

ADDITIONAL SENSE BYTES 


VALID bit 

0 A VALID bit set to zero indicates that the INFORMATION field is not defined in this manual or any command stan¬ 
dard. 

1 A VALID bit set to one indicates the INFORMATION field contains valid information as defined in this standard or a 
command standard. 

RESPONSE CODE field 

The contents of the RESPONSE CODE field indicate the error type and format of the sense data (see 2.4.1). For fixed for¬ 
mat sense data, the RESPONSE CODE field shall be set to 70h or 71 h. 

FILE MARK bit 

See the SSC-2 READ and SPACE commands for examples of FILEMARK bit usage. 
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EOM (End-of-Medium) bit 

See the SSC-2 READ, SPACE, and WRITE commands for examples of end-of-medium (EOM) bit usage. 

ILI (Incorrect length indicator) Bit 

See the SBC-2 READ LONG, SBC-2 WRITE LONG, and SSC-2 READ commands and for examples of incorrect length 
indicator (ILI) bit usage. 

SENSE KEY, ADDITONAL SENSE CODE, and ADDITIONAL SENSE CODE QUALIFIER fields 

The SENSE KEY, ADDITIONAL SENSE CODE, and ADDITIONAL SENSE CODE QUALIFIER fields are described in 
4.5.2.1. 

INFORMATION field 

The contents of the INFORMATION field are device-type or command specific and are defined in a command standard. 

ADDITIONAL SENSE LENGTH field 

The ADDITIONAL SENSE LENGTH field indicates the number of additional sense bytes that follow. The additional sense 
length shall be less than or equal to 244 (i.e., limiting the total length of the sense data to 252 bytes). If the sense data is 
being returned as parameter data by a REQUEST SENSE command, then the relationship between the ADDITIONAL 
SENSE LENGTH field and the CDB ALLOCATION LENGTH field is defined in 2.2.6. 

COMMAND-SPECIFIC INFORMATION field 

The COMMAND-SPECIFIC INFORMATION field contains information that depends on the command on which the excep¬ 
tion condition occurred. 

FIELD REPLACEABLE UNIT CODE field 

The FIELD REPLACEABLE UNIT CODE field is described in 2.4.1.1.5. 

SKSV (Sense-key Specific Valid) bit 

1 A sense-key specific valid (SKSV) bit set to one indicates the SENSE KEY SPECIFIC field contains valid informa¬ 
tion as defined in this standard. 

0 An SKSV bit set to zero indicates that the SENSE KEY SPECIFIC field is not as defined by this standard. 

SENSE KEY SPECIFIC field 

The SENSE KEY SPECIFIC field is described in 2.4.1.1.4. 

The additional sense bytes may contain vendor specific data that further defines the nature of the exception 
condition. 


2.4.1.3 Current errors 

Response codes 70h and 72h (current error) indicate that the sense data returned is the result of an error or 
exception condition on the task that returned the CHECK CONDITION status or a protocol specific failure con¬ 
dition. This includes errors generated during processing of the command. It also includes errors not related to 
any command that are detected during processing of a command (e.g., disk servo-mechanism failure, off-track 
errors, or power-up test errors). 

2.4.1.4 Deferred errors 

Response codes 71 h and 73h (deferred error) indicate that the sense data returned is the result of an error or 
exception condition that occurred during processing of a previous command for which GOOD, CONDITION 
MET, INTERMEDIATE, and INTERMEDIATE-CONDITION MET status has already been returned. Such com¬ 
mands are associated with the use of the immediate bit and with some forms of caching. Device servers that 
implement these features shall implement deferred error reporting. 

The deferred error may be indicated by returning CHECK CONDITION status to an application client accessed 
through a defined l_T nexus as described in this subclause. 
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If the task terminates with CHECK CONDITION status and the sense data describes a deferred error, the com¬ 
mand for the terminated task shall not have been processed. After the device server detects a deferred error 
condition, it shall return a deferred error according to the following rules: 

(a) If no external intervention is necessary to recover a deferred error, a deferred error indication shall not 
be returned unless required by the error handling parameters of a MODE SELECT command. The 
occurrence of the error may be logged; 

(b) If it is possible to associate a deferred error with an l_T nexus and with a particular function or a partic¬ 
ular subset of data, and the error is either unrecovered or required to be reported by the mode param¬ 
eters, then a deferred error indication shall be returned for a command received on the l_T nexus 
associated with the deferred error. If an application client request received on an l_T nexus other than 
the l_T nexus associated with the deferred error attempts to access the particular function or subset of 
data associated with the deferred error and the TST field equals 000b, then the device server shall 
respond to the command with a BUSY or ACA ACTIVE status according to the requirements in SAM-3. 
If an application client request received on an l_T nexus other than the l_T nexus associated with the 
deferred error attempts to access the particular function or subset of data associated with the deferred 
error and the TST field equals 001b, then the command attempting the access shall not be blocked by 
the deferred error and the cause of the deferred error may result in an error being reported for the 
command attempting the access; 

(c) If the device server is unable to associate a deferred error with an l_T nexus or with a particular subset 
of data, the device server shall return a deferred error for one command received on each l_T nexus. If 
multiple deferred errors have accumulated for an l_T nexus, only the last error shall be returned; 

(d) If the SCSI target device is unable to associate a deferred error with a particular logical unit, it shall 
establish a deferred error for every logical unit and shall return the deferred error for one command for 
each logical unit received on each appropriate l_T nexus; or 

(e) If a task has never entered the enabled task state, and a deferred error occurs, the task shall be termi¬ 
nated with CHECK CONDITION status and deferred error information returned in the sense data. If a 
deferred error occurs after a task has entered the enabled task state and the task is affected by the 
error, the task shall be terminated with CHECK CONDITION status and the current error information 
shall be returned in the sense data. In this case, if the current error information does not adequately 
define the deferred error condition, a deferred error may be returned after the current error information 
has been returned. If a deferred error occurs after a task has entered the enabled task state and the 
task completes successfully, the device server may choose to return the deferred error information 
after the completion of the current command in conjunction with a subsequent command that has not 
begun processing. 

Note. A deferred error may indicate that an operation was unsuccessful long after GOOD status was 
returned. If the application client is unable to replicate or recover from other sources the data that is 
being written using cached or buffered write operations, then synchronization commands should be 
performed before the critical data is destroyed. This is necessary for actions taken when deferred 
errors occur in the storing of the data. The synchronizing process should provide the necessary 
commands to allow returning CHECK CONDITION status and subsequent returning of deferred 
error sense information after all cached or buffered operations are completed. 
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2.4.1.5 Sense key and sense code definitions 
The sense keys are defined in table 27. 

Table 27 — Sense key descriptions (Sheet 1 of 2) 


Sense 

Key 

Description 

Oh 

NO SENSE: Indicates that there is no specific sense key information to be reported. This may 
occur for a successful command or for a command that receives CHECK CONDITION status 
because one of the FILEMARK, EOM, or ILI bits is set to one. 

1h 

RECOVERED ERROR: Indicates that the command completed successfully, with some recovery 
action performed by the device server. Details may be determined by examining the additional 
sense bytes and the INFORMATION field. When multiple recovered errors occur during one 
command, the choice of which error to report (e.g., first, last, most severe) is vendor specific. 

2h 

NOT READY: Indicates that the logical unit is not accessible. Operator intervention may be 
required to correct this condition. 

3h 

MEDIUM ERROR: Indicates that the command terminated with a non-recovered error condition 
that may have been caused by a flaw in the medium or an error in the recorded data. This sense 
key may also be returned if the device server is unable to distinguish between a flaw in the 
medium and a specific hardware failure (i.e., sense key 4h). 

4h 

HARDWARE ERROR: Indicates that the device server detected a non-recoverable hardware 
failure (e.g., controller failure, device failure, or parity error) while performing the command or 
during a self test. 

5h 

ILLEGAL REQUEST: Indicates that: 

a) The command was addressed to an incorrect logical unit number (see SAM-3); 

b) The command had an invalid task attribute (see SAM-3); 

c) The command was addressed to a logical unit whose current configuration prohibits processing 
the command; 

d) There was an illegal parameter in the CDB; or 

e) There was an illegal parameter in the additional parameters supplied as data for some commands 
(e.g., PERSISTENT RESERVE OUT). 

If the device server detects an invalid parameter in the CDB, it shall terminate the command with¬ 
out altering the medium. If the device server detects an invalid parameter in the additional param¬ 
eters supplied as data, the device server may have already altered the medium. 

6h 

UNIT ATTENTION: Indicates that a unit attention condition has been established (e.g., the 
removable medium may have been changed, a logical unit reset occurred). See SAM-3. 

7h 

DATA PROTECT: Indicates that a command that reads or writes the medium was attempted on a 
block that is protected. The read or write operation is not performed. 

8h 

BLANK CHECK: Indicates that a write-once device or a sequential-access device encountered 
blank medium or format-defined end-of-data indication while reading or that a write-once device 
encountered a non-blank medium while writing. 

9h 

VENDOR SPECIFIC: This sense key is available for reporting vendor specific conditions. 

Ah 

COPY ABORTED: Indicates an EXTENDED COPY command was aborted due to an error con¬ 
dition on the source device, the destination device, or both. 

Bh 

ABORTED COMMAND: Indicates that the device server aborted the command. The application 
client may be able to recover by trying the command again. 

Ch 

Obsolete 
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Table 27 — Sense key descriptions (Sheet 2 of 2) 


Sense 

Key 

Description 

Dh 

VOLUME OVERFLOW: Indicates that a buffered SCSI device has reached the end-of-partition 
and data may remain in the buffer that has not been written to the medium. One or more 
RECOVER BUFFERED DATA command(s) may be issued to read the unwritten data from the 
buffer. (See SSC-2.) 

Eh 

MISCOMPARE: Indicates that the source data did not match the data read from the medium. 

Fh 

Reserved 


2.4.1.6 Additional Sense and Additional Sense Qualifier codes 

Table 28 lists the Additional Sense (ASC) and Additional Sense Qualifier (ASCQ) codes. Code values are in 
hexadecimal. ANSI standard SPC-3 lists a more complete table in error description alphabetical order. This 
Table 28 list adequately covers all Seagate drives, however. 

Note. Table 28 is for reference only, as not all drives covered by this manual support all of the codes 
listed. Codes without sense key references may or may not be supported. 

Table 28 — Additional Sense and Additional Sense Qualifier codes 


ASC 
(byte 12) 

ASCQ 
(byte 13) 

Description 

Sense 

Key 

00 

00 

No Additional Sense Information 

0 

01 

00 

No Index/Logical Block Signal 

4 

02 

00 

No SEEK Complete 

4 

03 

00 

Peripheral Device Write Fault 

1,3, 4 

03 

86 

Write Fault Data Corruption 


04 

00 

Logical Unit Not Ready, Cause Not Reportable 

2 

04 

01 

Logical Unit Not Ready, Becoming Ready 

2 

04 

02 

Logical Unit Not Ready, SMART UNIT Required 

2 

04 

03 

Logical Unit Not Ready, Manual Intervention Required 

2 

04 

04 

Logical Unit Not Ready, Format in Progress 

2 

04 

09 

Logical Unit Not Ready, Self Test in Progress 

2 

04 

0A 

Logical Unit Not Ready, NVC recovery in progress after and exception event 

2 

04 

11 

Logical Unit Not Ready, Notify (Enable Spinup) required 

2 

04 

F0 

Logical unit not ready, super certify in progress 

2 

05 

00 

ILLEGAL REQUEST 

5 

06 

00 

UNIT ATTENTION 

6 

07 

00 

Data Protect 

7 

08 

00 

Logical Unit Communication Failure 

9, B 
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ASC 
(byte 12) 

ASCQ 
(byte 13) 

Description 

Sense 

Key 

08 

01 

Logical Unit Communication Time-Out 

B 

08 

02 

Logical Unit Communication Parity Error 


09 

00 

Track Following Error 

1,3,4 

09 

01 

Servo Fault 

1,4 

09 

04 

Head Select Fault 

3,4 

09 

OD 

Write to at least one copy of a redundant file failed 

1 

09 

OE 

Redundant files have < 50% good copies 

1 

09 

F8 

Calibration is needed but the QST is set without the Recal Only bit 

1 

09 

FF 

Servo Cal completed as part of self-test 

1 

OA 

00 

Error Log Overflow 


OA 

01 

Failed to write super certify log file 

3 

OA 

02 

Failed to read super certify log file 

3 

OB 

00 

Aborted Command 

B 

OB 

01 

Warning—Specified Temperature Exceeded 

1,6 

OB 

02 

Warning, Enclosure Degraded 

1 

OC 

00 

Write Error 

3 

OC 

01 

Write Error Recovered With Auto-Reallocation 

1 

OC 

02 

Write Error—Auto Reallocation Failed 

3 

OC 

03 

Write Error—Recommend Reassignment 

3 

OC 

FF 

Write Error—Too many error recovery revs 

3 

OD 

00 

Volume Overflow Constants 

D 

OE 

00 

Data Miscompare 

E 

10 

00 

IDCRC Or ECC Error 


11 

00 

Unrecovered Read Error 

1,3 

11 

01 

Read Retries Exhausted 


11 

02 

Error Too Long To Correct 


11 

04 

Unrecovered Read Error—Auto Reallocation Failed 

3 

11 

FF 

Unrecovered Read Error—Too many error recovery revs 

3 

12 

00 

Address Mark Not Found For ID Field 


12 

01 

Recovered Data Without ECC Using Previous Logical Block ID 


12 

02 

Recovered Data With ECC Using Previous Logical Block ID 
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ASC 
(byte 12) 

ASCQ 
(byte 13) 

Description 

Sense 

Key 

14 

00 

Logical Block Not Found 


14 

01 

Record Not Found 

3 

15 

00 

Random Positioning Error 


15 

01 

Mechanical Positioning Error 

1,3, 4 

15 

02 

Positioning Error Detected By Read Of Medium 


16 

00 

Data Synchronization Mark Error 

1,3, 4 

17 

00 

Recovered Data With No Error Correction Applied 


17 

01 

Recovered Data Using Retries 

1 

17 

02 

Recovered Data Using Positive Offset 

1 

17 

03 

Recovered Data Using Negative Offset 

1 

17 

05 

Recovered Data Using Previous Logical Block ID 


17 

06 

Recovered Data Without ECO—Data Auto Reallocated 


18 

00 

Recovered Data With ECO 

1 

18 

01 

Recovered Data With ECO And Retries Applied 

1 

18 

02 

Recovered Data With ECO And/Or Retries, Data Auto-Reallocated 

1 

18 

05 

Recovered Data—Recommand Reassignment 


18 

06 

Recovered Data Using ECO and Offsets 


18 

07 

Recovered Data With ECO—Data Rewritten 

1 

19 

00 

Defect List Error 

1,4 

19 

01 

Defect List Not Available 


19 

02 

Defect List Error In Primary List 


19 

03 

Defect List Error in Grown List 


19 

OE 

Fewer than 50% Defect List Copies 


1A 

00 

Parameter List Length Error 

5 

IB 

00 

Synchronous Data Transfer Error 


1C 

00 

Defect List Not Found 

1,4 

1C 

01 

Primary Defect List Not Found 


1C 

02 

Grown Defect List Not Found 


1C 

83 

Seagate Unique Diagnostic Code 


ID 

00 

Miscompare During Verify Operation 

E 

IF 

00 

Number of Defects Overflows the Allocated Space That The Read Defect Command 
Can Handle 

1 
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ASC 
(byte 12) 

ASCQ 
(byte 13) 

Description 

Sense 

Key 

20 

00 

Invalid Command Operation Code 

5 

20 

F3 

Invalid linked command operation code 

5 

21 

00 

Logical Block Address Out Of Range 

D 

24 

00 

Invalid Field In CDB 

5 

24 

01 

Illegal Queue Type for CDB (Low priority commands must be SIMPLE queue) 

5 

24 

FO 

Invalid LBA in linked command 

5 

24 

F2 

Invalid linked command operation code 

5 

24 

F3 

Illegal G->P operation request 

5 

25 

00 

Logical Unit Not Supported 

5 

26 

00 

Invalid Field In Parameter List 

5 

26 

01 

Parameter Not Supported 

5 

26 

02 

Parameter Value Invalid 

5 

26 

03 

Invalid Field Parameter—Threshold Parameter 

5 

26 

04 

Invalid Release of Active Persistent Reserve 

5 

26 

05 

Fail to read valid log dump data 

5 

26 

97 

Invalid Field Parameter—TMS Firmware Tag 


26 

98 

Invalid Field Parameter—Check Sum 


26 

99 

Invalid Field Parameter—Firmware Tag 


27 

00 

Write Protected 

7 

29 

00 

Flashing LED occurred 

4 

29 

00 

Power On, Reset, Or Bus Device Reset Occurred 

6 

29 

01 

Power-On Reset Occurred 

6 

29 

02 

SCSI Bus Reset Occurred 

6 

29 

03 

Bus Device Reset Function Occurred 

6 

29 

04 

Internal Reset Occurred 

6 

29 

05 

Transceiver Mode Changed To Single-Ended 

6 

29 

06 

Transceiver Mode Changed To LVD 

6 

29 

07 

Write Log Dump data to disk successful OR IT Nexus Loss 

6 

29 

08 

Write Log Dump data to disk fail 

6 

29 

09 

Write Log Dump Entry information fail 

6 

29 

OA 

Reserved disc space is full 

6 
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ASC 
(byte 12) 

ASCQ 
(byte 13) 

Description 

Sense 

Key 

29 

OB 

SDBP test service contained an error, examine status packet(s) for details 

6 

29 

OC 

SDBP incoming buffer overflow (incoming packet too big) 

6 

29 

CD 

Flashing LED occurred. (Cold reset) 

6 

29 

CE 

Flashing LED occurred. (Warm reset) 

6 

2A 

01 

Mode Parameters Changed 

6 

2A 

02 

Log Parameters Changed 

6 

2A 

03 

Reservations preempted 

6 

2A 

04 

Reservations Released 

6 

2A 

05 

Registrations Preempted 

6 

2C 

00 

Command Sequence Error 

5 

2F 

00 

Tagged Commands Cleared By Another Initiator 

6 

31 

00 

Medium Format Corrupted 

3 

31 

01 

Corruption in R/W format request 

3 

31 

91 

Corrupt World Wide Name (WWN) in drive information file 

3 

32 

00 

No Defect Spare Location Available 

4 

32 

01 

Defect List Update Error 

3, 4,5 

32 

02 

No Spares Available—Too Many Defects On One Track 


32 

03 

Defect list longer than allocated memory 

3 

33 

00 

Flash not ready for access 

3 

35 

00 

Unspecified Enclosure Services Failure 

4 

35 

01 

Unsupported Enclosure Function 

5 

35 

02 

Enclosure Services Unavailable 

2 

35 

03 

Enclosure Transfer Failure 

4 

35 

04 

Enclosure Transfer Refused 

4 

37 

00 

Parameter Rounded 

1 

3D 

00 

Invalid Bits In Identify Message 


3E 

03 

Logical Unit Failed Self Test 

4 

3E 

00 

Logical Unit Has Not Self Configured Yet 


3F 

00 

Target Operating Conditions Have Changed 

6 

3F 

01 

Device internal reset occurred 

6 

3F 

02 

Changed Operating Definition 

6 
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ASC 
(byte 12) 

ASCQ 
(byte 13) 

Description 

Sense 

Key 

3F 

05 

Device Identifier Changed 

6 

3F 

OF 

Echo buffer overwritten 

B 

3F 

80 

Buffer contents have changed 

1 

3F 

90 

Invalid APM Parameters 


3F 

91 

World Wide Name (WWN) Mismatch 

6 

40 

01 

DRAM Parity Error 

1,4 

40 

02 

Spinup Error recovered with retries 

1 

42 

00 

Power-On Or Self-Test Failure 

4 

42 

OA 

Port A failed loopback test 

4 

42 

OB 

Port B failed loopback test 

4 

43 

00 

Message Reject Error 

B 

44 

00 

Internal Target Failure 

1,3, 4 

44 

F2 

Data Integrity Check Failed on verify 

4 

44 

F6 

Data Integrity Check Failed during write 

4 

44 

FF 

XOR CDB check error 

4 

45 

00 

Select/Reselection Failure 

B 

47 

00 

SCSI Parity Error 

B 

47 

03 

Information Unit CRC Error 

B 

47 

80 

Fibre Channel Sequence Error 

B 

48 

00 

Initiator Detected Error Message Received 

B 

49 

00 

Invalid Message Received 

B 

4B 

00 

Data Phase Error 

B 

4B 

01 

Invalid transfer tag 

B 

4B 

02 

Too many write data 

B 

4B 

03 

ACK NAK Timeout 

B 

4B 

04 

NAK received 

B 

4B 

05 

Data Offset error 

B 

4B 

06 

Initiator response timeout 

B 

4C 

00 

Logical Unit Failed Self-Configuration 


4E 

00 

Overlapped Commands Attempted 

B 

55 

01 

XOR Cache is Not Available 
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ASC 
(byte 12) 

ASCQ 
(byte 13) 

Description 

Sense 

Key 

55 

04 

PRKT table is full 

5 

5B 1 

00 

Log Exception 


5B* 

01 

Threshold Condition Met 


5B* 

02 

Log Counter At Maximum 


5B* 

03 

Log List Codes Exhausted 


5C 

00 

RPL Status Change 

6 

5C 

01 

Spindles Synchronized 


5C 

02 

Spindles Not Synchronized 


5D 

00 

Failure Prediction Threshold Exceeded 

1,6 

5D 

FF 

False Failure Prediction Threshold Exceeded 

1,6 

65 

00 

Voltage Fault 

4 

80 

00 

General Firmware Error Qualifier 

9 

80 

86 

IOEDC Error on Read 

9 

80 

87 

IOEDC Error on Write 

9 

80 

88 

Host Parity Check Failed 

9 

80 

89 

IOEDC Error on Read Detected by Formatter 

9 

80 

8A 

Host FIFO Parity Error detected by Common Buffer 

9 

80 

8B 

Host FIFO Parity Error detected by frame buffer logic 

9 

80 

8C 

Host Data Frame Buffer Parity Error 

9 

81 

00 

Reassign Power—Fail Recovery Failed 


81 

00 

LA Check Error, LCM bit = 0 

4 

81 

00 

LA Check Error 

B 

B4 

00 

Unreported Deferred Errors have been logged on log page 34h 

6 


[1] Can be supported, but is a factory installed option. 
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3.0 


Command Reference 


This clause describes the commands supported by Seagate Disc Drives. 

Commands that have been supported prior to this manual being produced and that are now indicated as obso¬ 
lete will be described in this clause as obsolete. However, a description will be provided for such commands. 

Commands that have been declared obsolete by the T10 committee and were never supported by Seagate are 
not included in this manual. Commands that have not been supported in the past, but may be supported in the 
near future will be included in this manual. 

This clause contains information about the commands used by Seagate Parallel SCSI, Fibre Channel, and 
Serial Attached SCSI disc drives. This clause is organized to provide rapid access to command information. 

Two types of commands are supported by the drive: commands for all devices; and commands for direct 
access devices. The individual Product Manuals for each Seagate model drive list the Commands and param¬ 
eter pages that the particular drive supports. 

Commands sorted by command name 


Command name 

OP 

code 

[1] 

Command type 

Length 

clause 

Reference 

All 

devices 

Direct 

access 

devices 

6 

byte 

10 

byte 

12 

byte 

16 

byte 

32 

byte 

CHANGE DEFINITION 

40 h 

x [2] 







3.1 

COMPARE 

39h 

x [2] 







3.2 

COPY 

18h 

x [2] 







3.3 

COPY AND VERIFY 

3Ah 

x [2] 







3.4 

FORMAT UNIT 

04 h 


X 






3.5 

INQUIRY 

12h 

X 


x 





3.6 

LOCK-UNLOCK CACHE (10) 

36h 


x 






3.7 

LOCK-UNLOCK CACHE (16) 

92 h 


X 






3.8 

LOG SELECT 

4Ch 

x 



“x - 




3.9 

LOG SENSE 

4Dh 

X 



x 




3.10 

MODE SELECT (6) 

15h 


X 






3.11 

MODE SELECT (10) 

55 h 


X 






3.12 

MODE SENSE (6) 

1 Ah 


X 






3.13 

MODE SENSE (10) 

5Ah 


X 






3.14 

PERSISTENT RESERVE IN 

5Eh 


X 






3.15 

PERSISTENT RESERVE OUT 

5Fh 


X 






3.16 

READ (6) 

08h 


X 

~X~ 





3.19 

READ (10) [3] 

28 h 


X 






3.20 
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OP 

Command type 

Length 


Command name 

code 

All 

Direct 

6 

10 

12 

16 

32 

clause 

Reference 


[1] 

devices 

devices 

byte 

byte 

byte 

byte 

byte 


READ (12) 

A8h 


x 



~>r~ 



3.21 

READ (16) 

88h 


X 




^T” 


3.22 

READ (32) 

7Fh/0009h 


X 





^T” 

3.23 

READ BUFFER 

3Ch 

X 



~>T” 




3.24 

READ CAPACITY (10) 

25h 


X 


x 




3.25 

READ CAPACITY (16) 

9Eh/10h 


X 




^T” 


3.26 

READ DEFECT DATA (10) 

37h 


X 


X 




3.27 

READ DEFECT DATA (12) 

B7h 


X 



~>T” 



3.28 

READ LONG (10) 

3Eh 


X 


~>T” 




3.29 

READ LONG (16) 

9Eh 


X 




^T” 


3.30 

REASSIGN BLOCKS 

07h 


X 

^T” 





3.31 

RECEIVE DIAGNOSTIC RESULTS 

ICh 

X 


X 





3.32 

RELEASE (6) 

17h 


x[2] 

x 





3.33 

RELEASE (10) 

57h 


x[2] 


X 




3.34 

REPORT DEVICE IDENTIFIER 

A3h/05h 

X 




X 



3.35 

REPORT LUNS 

AOh 


X 






3.36 

REQUEST SENSE 

03h 

X 


~>T” 





3.37 

RESERVE (6) 

16h 


x[2] 

X 





3.38 

RESERVE (10) 

56 h 


x[2] 


X 




3.39 

REZERO UNIT 

01 h 


x[2] 

~>T” 





3.40 

SEEK (6) 

OBh 


x[2] 

x 





3.41 

SEEK EXTENDED (10) 

2Bh 


x 


X 




3.42 

SEND DIAGNOSTIC 

1 Dh 

X 


^T” 





3.43 

SET DEVICE IDENTIFIER 

A4h/06h 

X 







3.44 

START/STOP UNIT 

IBh 


x 

~>T” 





3.45 

SYNCHRONIZE CACHE (10) 

35h 


x 


X 




3.46 

SYNCHRONIZE CACHE (16) 

91 h 


x 




X 


3.47 

TEST UNIT READY 

00 h 

X 


~>T” 





3.48 

VERIFY(IO) 

2Fh 


x 


~>T” 




3.49 

VERIFY (12) 

AFh 


x 



X 



3.50 

VERIFY (16) 

8Fh 


x 






3.51 

VERIFY (32) 

7Fh/000Ah 


X 





~>T” 

3.52 

WRITE (6) 

OAh 


x 

~>T” 





3.53 

WRITE (10) 

2Ah 


x 






3.54 

WRITE (12) 

AAh 


x 






3.55 

WRITE (16) 

8Ah 


X 






3.56 

WRITE (32) 

7Fh/000Bh 


x 





~>T” 

3.57 

WRITE AND VERIFY (10) 

2Eh 


x 


X 




3.58 

WRITE AND VERIFY (12) 

AEh 


x 



X 



3.59 

WRITE AND VERIFY (16) 

8Eh 


x 




~>T” 


3.60 
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Command name 

OP 

code 

[1] 

Command type 

Length 

clause 

Reference 

All 

devices 

Direct 

access 

devices 

6 

byte 

10 

byte 

12 

byte 

16 

byte 

32 

byte 

WRITE AND VERIFY (32) 

7Fh/000Ch 


x 






3.61 

WRITE BUFFER 

3Bh 

x 







3.62 

WRITE LONG 

3Fh 


X 


X 




3.63 

WRITE LONG (16) 

9Fh/11h 


X 






3.64 

WRITE SAME (10) 

41 h 


X 






3.65 

WRITE SAME (16) 

93 h 


X 






3.66 

WRITE SAME (32) 

7Fh/000Dh 


X 





X 

3.67 


[1] Command Operation Code a one byte hexidecimal number between OOh and FF hex. 

[2] Command has been declared obsolete by the T10 committee. Flowever, it is included because it may be 
implemented on some products. 

[3] Formerly called Read Extended. 
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3.1 CHANGE DEFINITION command 

This command has been declared obsolete by the T10 committee. However, it is included because it 
may be implemented on some products. 

The CHANGE DEFINITION command (see table 29) is used to modify the operating definition of the device 
server(s) with respect to commands from the sending initiator or with respect to commands from all initiators. 

Table 29 — CHANGE DEFINITION command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (40h) 

3 

Reserved 

4 

Reserved SAVE 

5 

Reserved DEFINITION PARAMETER 

6 

Reserved 

7 

Reserved 

8 

Reserved 

9 

Reserved 

10 

PARAMETER DATA LENGTH 

11 

CONTROL 


If reservations are active, they shall affect the execution of the CHANGE DEFINITION command as follows. If 
the SCSI device does not allow different operating definitions for each initiator, a reservation conflict shall occur 
when a CHANGE DEFINITION command is received from an initiator other than the one holding a logical unit 
reservation. If any initiator has an extent or element reservation on an SCSI device, no other initiator may affect 
the operating definition of the initiator holding the reservation by use of the CHANGE DEFINITION command. 

A save control bit (SAVE) of zero indicates that the device server shall not save the operating definition. A 
Save bit of one indicates that the device server shall save the operating definition in non-volatile memory. 

The definition parameter field is defined in table 14. 

Table 30 — Definition parameter field 


Value 

Meaning of definition parameter 

OOh 

Use current operating definition 

03h 

SCSI-2 operating definition 

04h 

SCSI-3 operating definition 

01 - 02h 

Reserved for historical uses 

05 - 3Eh 

Reserved 

3Fh 

Manufacturer default definition 

40 - 7Fh 

Vendor specific 
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The current operating definition parameter values establish operating definitions compatible with the applicable 
SCSI standard. Definitions supported by an SCSI device are returned in the implemented operating definition 
page (see 8.4.4 in SCSI-3 Primary Commands Rev 11). 

The parameter data length field specifies the length in bytes of the parameter data that shall be transferred 
from the application client to the device server. A parameter data length of zero indicates that no data shall be 
transferred. This condition shall not be considered as an error. Parameter data length values greater than zero 
indicate the number of bytes of parameter data that shall be transferred. 

The parameter data is vendor-specific. 

Note. 1 The parameter data may be used to specify a password to validate an operating definition 
change. 

The CHANGE DEFINITION command causes one of the operating definition modifications listed below: 

(a) Change the operating definition of a logical unit relative to the initiator that issued the command: In this 
case, the target is capable of maintaining a separate operating definition for each logical unit relative to 
each initiator in the system; 

(b) Change the operating definition of all logical units in the target relative to the initiator that issued the 
command: In this case, the target is capable of maintaining a unique operating definition, for each initi¬ 
ator in the system, that applies to all logical units in the target; 

(c) Change the operating definition of a logical unit relative to all initiators in the system: In this case, the 
target is capable of maintaining a separate operating definition for each logical unit relative to all initia¬ 
tors in the system; or 

(d) Change the operating definition of all logical units in the target relative to all initiators in the system: In 
this case, the target is capable of maintaining only one operating definition. 

Note. 2 This standard does not provide a direct means to determine which of the above four methods has 
been implemented. An indirect means of determining which method is implemented exists in that 
the device server is required to inform affected initiators of operating definition changes via the unit 
attention condition. 

Note. 3 The modifications listed c) and d) above may result in incompatibilities if other initiators are using 
a different SCSI version. 

The operating definition is modified after successful completion of the command. The application client should 
verify the new operating definition by issuing an INQUIRY command requesting the implemented operating 
definition page (see 8.4.1 in SCSI -3). 

Note. 4 The method of changing the operating definition is vendor-specific. Some implementations may 
require that the target’s operating mode be reinitialized as if a power-up or hard reset had occurred. 
Other implementations may modify only those operating definitions that are affected by the 
CHANGE DEFINITION command. 

If the CHANGE DEFINITION command is not executed successfully for any reason, the operating definition 
shall remain the same as it was before the CHANGE DEFINITION command was attempted. If it is impossible 
to return to the previous operating definition, a unit attention condition shall be generated. 

Note. 5 The present operating definition of the target may always be interrogated through the INQUIRY 
command. When an SCSI-3 target has its operating definition changed to an older SCSI operating 
definition, certain changes are needed to promote compatibility with preexisting older SCSI initia¬ 
tors. 

After a power-on condition or a hard reset condition, the target shall set its initial operating definition of the 
device server(s) to the last saved value (if saving is implemented), or its default value (if saving is not imple¬ 
mented). 
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3.2 COMPARE command 

Obsolete. If received, a CHECK CONDITION status is sent. 

3.3 COPY command 

Obsolete. If received, a CHECK CONDITION status is sent. 

3.4 COPY AND VERIFY command 

Obsolete. If received, a CHECK CONDITION status is sent. 
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3.5 


FORMAT UNIT command 


3.5.1 FORMAT UNIT command overview 

The FORMAT UNIT command (see table 31) requests that the device server format the medium into applica¬ 
tion client accessible logical blocks as specified in the number of blocks and block length values received in the 
last mode parameter block descriptor (see 4.3.4) in a MODE SELECT command (see SPC-4). In addition, the 
device server may certify the medium and create control structures for the management of the medium and 
defects. The degree that the medium is altered by this command is vendor-specific. 

If a device server receives a FORMAT UNIT command before receiving a MODE SELECT command with a 
mode parameter block descriptor the device server shall use the number of blocks and block length at which 
the logical unit is currently formatted (i.e., no change is made to the number of blocks and the block length of 
the logical unit during the format operation). 


Table 31 — FORMAT UNIT command 


Bit 

Byte 

7 

6 

5 

4 

3 

2 1 0 

0 

OPERATION CODE (04h) 

1 

FMT- 

PINFO 

RTO_REQ 

LONG- 

LIST 

FMTDATA 

CMPLIST 

DEFECT LIST FORMAT 

2 

Vendor Specific 

3 


Obsolete 


4 



5 

CONTROL 


The simplest form of the FORMAT UNIT command (i.e., a FORMAT UNIT command with no parameter data) 
accomplishes medium formatting with little application client control over defect management. The device 
server implementation determines the degree of defect management that is to be performed. Additional forms 
of this command increase the application client's control over defect management. The application client may 
specify: 

a) defect list(s) to be used; 

b) defect locations; 

c) that logical unit certification be enabled; and 

d) exception handling in the event that defect lists are not accessible. 

While performing a format operation, the device server shall respond to commands attempting to enter into the 
task set except INQUIRY commands, REPORT LUNS commands, and REQUEST SENSE commands with 
CHECK CONDITION status with the sense key set to NOT READY and the additional sense code set to LOG¬ 
ICAL UNIT NOT READY, FORMAT IN PROGRESS. Handling of commands already in the task set is vendor- 
specific. 

The PROGRESS INDICATION field in parameter data returned in response to a REQUEST SENSE command 
(see SPC-4) may be used by the application client at any time during a format operation to poll the logical unit’s 
progress. While a format operation is in progress unless an error has occurred, a device server shall respond 
to a REQUEST SENSE command by returning parameter data containing sense data with the sense key set to 
NOT READY and the additional sense code set to LOGICAL UNIT NOT READY, FORMAT IN PROGRESS 
with the sense key specific bytes set for progress indication (see SPC-4). 
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FMTPINFO (Format Protection Information) bit 

A format protection information (FMTPINFO) bit (see table 36) specifies if the device server enables or disables the use of 
protection information. 

RTO_REQ (Reference Tag Own Request) bit 

The reference tag own request (RTO_REQ) bit (see table 36) specifies whether the application client or the device server 
has ownership of the LOGICAL BLOCK REFERENCE TAG field in protection information. 

Following a successful format, the P TYPE field in the READ CAPACITY (16) parameter data (see 1.6.2) indicates the type 
of protection currently in effect on the logical unit. 

When protection information is written during a FORMAT UNIT command (i.e., the FMTPINFO bit is set to one) protection 
information shall be written to a default value of FFFFFFFF_FFFFFFFFh. 

LONGLIST bit 

0 A LONGLIST bit set to zero specifies that the parameter list, if any, contains a short parameter list header as defined 
in table 34. 

1 A LONGLIST bit set to one specifies that the parameter list, if any, contains a long parameter list header as defined 
in table 35. If the FMTDATA bit is set to zero, the LONGLIST bit shall be ignored. 

FMTDATA (Format Data) 

0 A format data (FMTDATA) bit set to zero specifies that no parameter list be transferred from the data-out buffer. 

1 A FMTDATA bit set to one specifies that the FORMAT UNIT parameter list (see table 33) shall be transferred from 

the data-out buffer. The parameter list consists of a parameter list header, followed by an optional initialization pat¬ 
tern descriptor, followed by an optional defect list. 

CMPLST (Complete List) 

0 A complete list (CMPLST) bit set to zero specifies that the defect list included in the FORMAT UNIT parameter list 
shall be used in an addition to the existing list of defects. As a result, the device server shall construct a new GLIST 
that contains: 

a) the existing GLIST; 

b) the DLIST, if it is sent by the application client; and 

c) the CLIST, if certification is enabled (i.e., the device server may add any defects it detects during the format 
operation). 

1 A CMPLST bit set to one specifies that the defect list included in the FORMAT UNIT parameter list is a complete list 
of defects. Any existing defect list except the PLIST shall be ignored by the device server. As a result, the device 
server shall construct a new GLIST that contains: 

a) the DLIST, if it is sent by the application client; and 

b) the CLIST, if certification is enabled (i.e., the device server may add any defects it detects during the format 
operation). 

Note. If the FMTDATA bit is set to zero, the CMPLIST bit shall be ignored. 

DEFECT LIST FORMAT field 

The DEFECT LIST FORMAT field specifies the format of the address descriptors in the defect list if the FMT¬ 
DATA bit is set to one (see table 32). 


Table 32 defines the address descriptor usage for the FORMAT UNIT command. 
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Table 32 — FORMAT UNIT command address descriptor usage 


Field in the FORMAT UNIT CDB 

DEFECT LIST 
LENGTH field in the 
parameter list header 

Type a 

Comments f 

FMTDATA 

CMPLST 

DEFECT LIST 
FORMAT 

0 

Any 

000B 

Not available 

M 

Vendor-specific defect 
information 

1 

0 

000B 

(short block) 

Zero 

0 

See 13 and ^ 

1 

1 

0 

See 1:3 and e 

1 

0 

Nonzero 

0 

See c and d 

1 

1 

0 

See 1:3 and e 



Oil B 

(long block) 

Zero 

0 

See 1:3 and d 



0 

See 1:3 and e 

1 

0 

Nonzero 

0 

See c and ^ 

1 

1 

0 

See c and e 

1 

0 

100b 

(bytes 

from 

index) 

Zero 

0 

See and 

1 

1 

0 

See and 

1 

0 

Nonzero 

0 

See and 

1 

1 

0 

See and 

1 

0 

101b 

(physical 

sector) 

Zero 

0 

See and 

1 

1 

0 

See and 

1 

0 

Nonzero 

0 

See and 

1 

1 

0 

See and 

1 

0 

110b 

(vendor 

specific) 

Vendor specific 

0 


1 

1 

0 


All others 

Reserved. 


a M = implementation is mandatory. O = implementation is optional. 


b No DUST is included in the parameter list. 

c A DUST is included in the parameter list. The device server shall add the DLIST defects to the new GUST, 
d The device server shall add existing GUST defects to the new GLIST (i.e., use the existing GUST). 
e The device server shall not add existing GUST defects to the new GUST (i.e., discard the existing GLIST). 

f All the options described in this table cause a new GLIST to be created during processing of the FORMAT UNIT com¬ 
mand as described in the text. 
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3.5.2 


FORMAT UNIT parameter list 


3.5.2.1 FORMAT UNIT parameter list overview 

Table 33 defines the FORMAT UNIT parameter list. 

Table 33 — FORMAT UNIT parameter list 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 to 3 or 

0 to 7 

Parameter List Header (see table 34 or table 35 in 3.5.3) 




initialization Pattern Descriptor (if any) (see table 37, in 3.5.4) 




Defect List (if any) 




PARAMETER LIST HEADER field 

The PARAMETER LIST HEADER is defined in 3.5.3. 

INITIALIZATION PATTERN DESCRIPTOR field 

The INITIALIZATION PATTERN DESCRIPTOR, if any, is defined in 3.5.4. 

DEFECT LIST field 

The DEFECT LIST, if any, contains address descriptors (see Table 32 —) each specifying a location on the 
medium that the device server shall exclude from the application client accessible part. This is called the 
DLIST. 

3.5.3 Parameter list header 

The parameter list headers (see table 34 and table 35) provide several optional format control parameters. 
Device servers that implement these headers provide the application client additional control over the use of 
the four defect sources, and the format operation. If the application client attempts to select any function not 
implemented by the device server, the device server shall terminate the command with CHECK CONDITION 
status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN 
PARAMETER LIST. 
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The short parameter list header (see table 34) is used if the longlist bit is set to zero in the FORMAT UNIT 
CDB. 

Table 34 — Short parameter list header 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

Reserved 

PROTECTION FIELDS USAGE 

1 

FOV 

DPRY 

DCRT 

STPF 

IP 

Obsolete 

IMMED 

Vendor 

specific 

2 

(MSB) 



DEFECT LIST LENGTH 




3 








(LSB) 


The long parameter list header (see table 35) is used if the longlist bit is set to one in the FORMAT UNIT 
CDB. 

Table 35 — Long parameter list header 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

Reserved 

PROTECTION FIELDS USAGE 

1 

FOV 

DPRY 

DCRT 

STPF 

IP 

Obsolete 

IMMED 

Vendor 

specific 

2 

Reserved 

3 

Reserved 

4 

(MSB) 



DEFECT LIST LENGTH 




7 








(LSB) 


The PROTECTION FIELD USAGE field in combination with the FMTPINFO bit and the RTO_REQ bit (see 
table 36) specifies the requested protection type (see SBC-3). 


Table 36 — FMTPINFO bit, RTO_REQ bit, and PROTECTION FIELDS USAGE field 


Device server indication 

Application client specification 

Description 

SPT a 

PROTECT b 

FMTPINFO 

RTO_REQ 

PROTECTION 
FIELD USAGE 

xxxb 

0 

0 

0 

000b 

The logical unit shall be formatted to 
type 0 protection c (see SBC-3) resulting 
in the RTO ENABLE field d being set to 
000b. 

xxxb 

0 

0 

0 

>000b 

Illegal e 

xxxb 

0 

0 

1 

xxxb 

Illegal f 

xxxb 

0 

1 

x 

xxxb 

Illegal f 


SCSI Commands Reference Manual, Rev. A 


61 






Table 36 — FMTPINFO bit, RTO_REQ bit, and PROTECTION FIELDS USAGE field 


Device server indication 

Application client specification 

Description 

SPT a 

PROTECT b 

FMTPINFO 

RTO_REQ 

PROTECTION 
FIELD USAGE 

xxxb 

1 

0 

0 

000b 

The logical unit shall be formatted to 
type 0 protection c (see SBC-3) resulting 
in the RTO_ENABLE field d being set to 
000b. 

xxxb 

1 

0 

0 

>000b 

Illegal e 

xxxb 

1 

0 

1 

xxxb 

Illegal f 

000b 

001b 

011b 

1 

1 

0 

000b 

The logical unit shall be formatted to 
type 1 protection 9 (see SBC-3) resulting 
in the RTO ENABLE field d being set to 
000b. 

000b 

001b 

011b 

1 

1 

0 

>000b 

Illegal e 

000b 

1 

1 

1 

xxxb 

Illegal f 

001b 

1 

1 

1 

000b 

The logical unit shall be formatted to 
type 2 protection 9 (see SBC-3) resulting 
in the RTO_ENABLE field d being set to 
001b. 

001b 

1 

1 

1 

>000b 

Illegal e 

011b 

1 

1 

1 

000b 

Illegal e 

011b 

1 

1 

1 

001b 

The logical unit shall be formatted to 
type 3 protection. 9 (see SBC-3) result¬ 
ing in the RTO_ENABLE field d being 
set to 010b. 

011b 

1 

1 

1 

>001 b 

Illegal e 

010b 

1 

1 

x 

xxxb 

Reserved 

Ixxb 

1 

1 

x 

xxxb 

Reserved 


a See the Extended INQUIRY Data VPD page (see SPC-4) for the definition of the spt field, 
b See the standard INQUIRY data (see SPC-4) for the definition of the protect bit. 

c The device server shall format the medium to the block length specified in the mode parameter block descriptor of the 
mode parameter header (see SPC-4). 

d See the READ CAPACITY command (see 3.25.1) for the definition of the rto_enable field. 

e The device server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL 
REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST, 
f The device server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL 
REQUEST and the additional sense code set to INVALID FIELD IN CDB. 
g The device server shall format the medium to the block length specified in the mode parameter block descriptor of the 
mode parameter header plus eight (e.g., if the block length is 512, then the formatted block length is 520). Following a 
successful format, the prot_en bit in the READ CAPACITY (16) parameter data (see 3.26.1) indicates whether protection 
information (see SBC-3) is enabled. 
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FOV (Format Options Valid) bit 

0 A format options valid (FOV) bit set to zero specifies that the device server shall use its default settings for the 
DPRY, DCRT, STPF, and IP bits. If the FOV bit is set to zero, the application client shall set these bits to zero. If the 
FOV bit is set to zero and any of the other bits listed in this paragraph are not set to zero, the device server shall ter¬ 
minate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the addi¬ 
tional sense code set to INVALID FIELD IN PARAMETER LIST. 

1 A FOV bit set to one specifies that the device server shall examine the values of the DPRY, DCRT, STPF, and IP 
bits. When the FOV bit is set to one, the DPRY, DCRT, STPF, and IP bits are defined as follows. 

DPRY (Disable Primary) bit 

0 A disable primary (DPRY) bit set to zero specifies that the device server shall not use parts of the medium identified 
as defective in the PLIST for application client accessible logical blocks. If the device server is not able to locate the 
PLIST or it is not able to determine whether a PLIST exists, it shall take the action specified by the STPF bit. 

1 A DPRY bit set to one specifies that the device server shall not use the PLIST to identify defective areas of the 
MEDIUM. The PLIST shall not be deleted. 

DCRT (disable certification) bit 

0 A disable certification (DCRT) bit set to zero specifies that the device server shall perform a vendor-specific medium 
certification operation to generate a CLIST. 

1 A DCRT bit set to one specifies that the device server shall not perform any vendor-specific medium certification 
process or format verification operation. 

STPF bit 

The stop format (STPF) bit controls the behavior of the device server if one of the following events occurs: 

a) The device server has been requested to use the PLIST (i.e., the DPRY bit is set to zero) or the GLIST (i.e., the 
CMPLST bit is set to zero) and the device server is not able to locate the list or determine whether the list exists; 
or 

b) The device server has been requested to use the PLIST (i.e., the DPRY bit is set to zero) or the GLIST (i.e., the 
CMPLST bit is set to zero), and the device server encounters an error while accessing the defect list. 

STPF (Stop Format) bit 

0 A STPF bit set to zero specifies that, if one or both of these events occurs, the device server shall continue to pro¬ 
cess the FORMAT UNIT command. The device server shall return CHECK CONDITION status at the completion of 
the FORMAT UNIT command with the sense key set to RECOVERED ERROR and the additional sense code set to 
either DEFECT LIST NOT FOUND if the condition described in item a) occurred, or DEFECT LIST ERROR if the 
condition described in item b) occurred. 

1 A STPF bit set to one specifies that, if one or both of these events occurs, the device server shall terminate the 
FORMAT UNIT command with CHECK CONDITION status and the sense key shall be set to MEDIUM ERROR with 
the additional sense code set to either DEFECT LIST NOT FOUND if the condition described in item a) occurred, or 
DEFECT LIST ERROR if the condition described in item b) occurred. 

Note. The use of the FMTDATA bit, the CMPLST bit, and the parameter list header allow the application 
client to control the source of the defect lists used by the FORMAT UNIT command. Setting the 
DEFECT LIST LENGTH field to zero allows the application client to control the use of PLIST and 
CLIST without having to specify a DLIST. 

IP (initialization pattern) bit 

0 An initialization pattern (IP) bit set to zero specifies that an initialization pattern descriptor is not included and that 
the device server shall use its default initialization pattern. 

1 An IP bit set to one specifies that an initialization pattern descriptor (see 3.5.4) is included in the FORMAT UNIT 
parameter list following the parameter list header. 
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IMMED (Immediate) bit 

0 An immediate (IMMED) bit set to zero specifies that the device server shall return status after the format operation 
has completed. 

1 An IMMED bit value set to one specifies that the device server shall return status after the entire parameter list has 
been transferred. 

DEFECT LIST LENGTH field 

The DEFECT LIST LENGTH field specifies the total length in bytes of the defect list (i.e., the address descriptors) that fol¬ 
lows and does not include the initialization pattern descriptor, if any. The formats for the address descriptor(s) are shown in 
Table 32 —. 

Short block format address descriptors and long block format address descriptors should be in ascending 
order. Bytes from index format address descriptors and physical sector format address descriptors shall be in 
ascending order. More than one physical or logical block may be affected by each address descriptor. If the 
address descriptors are not in the required order, the device server shall terminate the command with CHECK 
CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to 
INVALID FIELD IN PARAMETER LIST. 

3.5.4 Initialization pattern descriptor 

The initialization pattern descriptor specifies that the device server initialize logical blocks to a specified pat¬ 
tern. The initialization pattern descriptor (see table 37) is sent to the device server as part of the FORMAT 
UNIT parameter list. 


Table 37 — Initialization pattern descriptor 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

IP MODIFIER 

SI 

Reserved 

1 

INITIALIZATION PATTERN TYPE 

2 

(MSB) 


INITIALIZATION PATTERN LENGTH (N - 3) 



3 








(LSB) 

4 




INITIALIZATION PATTERN 




N 
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IP MODIFIER (Initilization Pattern Modifier) field 

The initialization pattern modifier (IP MODIFIER) field (see table 38) specifies the type and location of a header that modi¬ 
fies the initialization pattern. 


Table 38 - 

- Initialization pattern modifier (IP MODIFIER) field 

Code 

Description 

00b 

No header. The device server shall not modify the initialization pattern. 

01b 

The device server shall overwrite the initialization pattern to write the LBA in the first four bytes of each 
logical block. The LBA shall be written with the most significant byte first. If the LBA is larger than four 
bytes, the least significant four bytes shall be written ending with the least significant byte. 

10b 

The device server shall overwrite the initialization pattern to write the LBA in the first four bytes of each 
physical block contained within the logical block. The lowest numbered logical block or part thereof that 
occurs within the physical block is used. The LBA shall be written with the most significant byte first. If the 
LBA is larger than four bytes the least significant four bytes shall be written ending with the least significant 
byte. 

11b 

Reserved. 


SI (Security Initialize) bit 

A security initialize (SI) bit set to one specifies that the device server shall attempt to write the initialization pat¬ 
tern to all areas of the medium including those that may have been reassigned (i.e., are in a defect list). An SI 
bit set to one shall take precedence over any other FORMAT UNIT CDB field. The initialization pattern shall be 
written using a security erasure write technique. Application clients may choose to use this command multiple 
times to fully erase the previous data. Such security erasure write technique procedures are outside the scope 
of the standard. The exact requirements placed on the security erasure write technique are vendor-specific. 
The intent of the security erasure write is to render any previous user data unrecoverable by any analog or dig¬ 
ital technique. 

0 An SI bit set to zero specifies that the device server shall initialize the application client accessible part of the 
medium. The device server is not required to initialize other areas of the medium. However, the device server shall 
format the medium as defined in the FORMAT UNIT command. 

1 When the SI bit is set to one, the device server need not write the initialization pattern over the header and other 
header and other parts of the medium not previously accessible to the application client. If the device server is 
unable to write over any part of the medium that is currently accessible to the application client or may be made 
accessible to the application client in the future (e.g., by clearing the defect list), it shall terminate the command with 
CHECK CONDITION status with the sense key set to MEDIUM ERROR and the additional sense code set to the 
appropriate value for the condition. The device server shall attempt to rewrite all remaining parts of the medium 
even if some parts are not able to be rewritten. 
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INITIALIZATION PATTERN TYPE field 


The INITIALIZATION PATTERN TYPE field (see table 39) specifies the type of pattern the device server shall 
use to initialize each logical block within the application client accessible part of the medium. All bytes within a 
logical block shall be written with the initialization pattern. The initialization pattern is modified by the IP modi¬ 
fier field as described in table 38. 


Table 39 — INITIALIZATION PATTERN TYPE field 


Code 

Description 

OOh 

Use a default initialization pattern a 

01 h 

Repeat the pattern specified in the INITIALIZATION PATTERN field as required to fill the logical 
block b 

02h - 7Fh 

Reserved 

80h - FFh 

Vendor-specific 

a If the INITIALIZATION PATTERN LENGTH field is not set to zero, the device server shall terminate the 
command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the 
additional sense code set to INVALID FIELD IN PARAMETER LIST. 
b If the INITIALIZATION PATTERN LENGTH field is set to zero, the device server shall terminate the 
command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the 
additional sense code set to INVALID FIELD IN PARAMETER LIST. 


INITIALIZATION PATTERN LENGTH field 

The INITIALIZATION PATTERN LENGTH field specifies the number of bytes contained in the initialization 
pattern field. If the initialization pattern length exceeds the current block length the device server shall termi¬ 
nate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the 
additional sense code set to INVALID FIELD IN PARAMETER LIST. 

INITIALIZATION PATTERN field 

The INITIALIZATION PATTERN field specifies the initialization pattern. The initialization pattern is modified by 
the IP MODIFIER field. 

3.5.5 Address descriptor formats 

3.5.5.1 Address descriptor formats overview 

This subclause describes the address descriptor formats used in the FORMAT UNIT command, the READ 
DEFECT DATA commands (see 3.27 and 3.28), and the Translate Address diagnostic pages (see 4.1.3) of the 
SEND DIAGNOSTIC command and the RECEIVE DIAGNOSTIC RESULTS command. 

The format type of an address descriptor is specified with: 

a) the DEFECT LIST FORMAT field in the CDB, for the FORMAT UNIT command and the READ DEFECT DATA 
commands; 

b) the SUPPLIED FORMAT field, for the Translate Address diagnostic pages; or 

c) the TRANSLATE FORMAT field, for the Translate Address diagnostic pages. 
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Table 40 defines the types of address descriptors. 


Table 40 — Address descriptor formats 


Format type 

Description 

Reference 

000b 

Short block format address descriptor 

3.5.5.2 

011b 

Long block format address descriptor 

3.5.5.3 

100b 

Bytes from index format address descriptor 

3.5.5.4 

101b 

Physical sector format address descriptor 

3.5.5.5 

110b 

Vendor-specific 

All others 

Reserved 


3.5.5.2 Short block format address descriptor 

A format type of 000b specifies the short block format address descriptor defined in table 41. 

Table 41 — Short block format address descriptor (000b) 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

(MSB) 


SHORT BLOCK ADDRESS 


3 







(LSB) 


SHORT BLOCK ADDRESS field 

For the FORMAT UNIT command, the short block address field contains the four-byte LBA of a defect. For 
the READ DEFECT DATA commands, the short block address field contains a vendor-specific four-byte 
value. For the Translate Address diagnostic pages, the short block address field contains a four-byte LBA or 
a vendor-specific four byte value that is greater than the capacity of the medium. 

3.5.5.3 Long block format address descriptor 

A format type of 011b specifies the long block format address descriptor defined in table 42. 

Table 42 — Long block format address descriptor (011b) 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

(MSB) 



LONG BLOCK ADDRESS 



7 







(LSB) 


LONG BLOCK ADDRESS field 

For the FORMAT UNIT command, the LONG BLOCK ADDRESS field contains the eight-byte logical block 
address of a defect. For the READ DEFECT DATA commands, the LONG BLOCK ADDRESS field contains a 
vendor-specific eight-byte value. For the Translate Address diagnostic pages, the LONG BLOCK ADDRESS 
field contains a four-byte LBA or a vendor-specific four byte value that is greater than the capacity of the 
medium. 
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3.5.5.4 Bytes from index format address descriptor 


A format type of 100b specifies the bytes from index address descriptor defined in table 43. For the FORMAT 
UNIT command and the READ DEFECT DATA commands, this descriptor specifies the location of a defect 
that is either the length of one track or is no more than eight bytes long. For the Translate Address diagnostic 
pages, this descriptor specifies the location of a track or the first byte or last byte of an area. 


Table 43 — Bytes from index format address descriptor (100b) 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

(MSB) CYLINDER NUMBER 

2 

(LSB) 

3 

HEAD NUMBER 

4 

(MSB) BYTES FROM INDEX 

7 

(LSB) 


CYLINDER NUMBER field 

The CYLINDER NUMBER field contains the cylinder number. 

HEAD NUMBER field 

The HEAD NUMBER field contains the head number. 

BYTES FROM INDEX field 

The BYTES FROM INDEX field contains the number of bytes from the index (e.g., from the start of the track) to the location 
being described. A BYTES FROM INDEX field set to FFFFFFFFh specifies that the entire track is being described. 

For sorting bytes from index format address descriptors, the cylinder number is the most significant part of the 
address and the bytes from index is the least significant part of the address. More than one logical block may 
be described by this descriptor. 
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3.5.5.5 Physical sector format address descriptor 

A format type of 101 b specifies the physical sector address descriptor defined in table 44. For the FORMAT 
UNIT command and the READ DEFECT DATA commands, this descriptor specifies the location of a defect 
that is either the length of one track or the length of one sector. For the Translate Address diagnostic pages, 
this descriptor specifies the location of a track or a sector. 


Table 44 — Physical sector format address descriptor (101b) 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

(MSB) CYLINDER NUMBER 

2 

(LSB) 

3 

HEAD NUMBER 

4 

(MSB) SECTOR NUMBER 

7 

(LSB) 


CYLINDER NUMBER field 

The CYLINDER NUMBER field contains the cylinder number. 

HEAD NUMBER field 

The FIEAD NUMBER field contains the head number. 

SECTOR NUMBER field 

The SECTOR NUMBER field contains the sector number. A SECTOR NUMBER field set to FFFFFFFFh specifies that the 
entire track is being described. 

For sorting physical sector format address descriptors, the cylinder number is the most significant part of the 
address and the sector number is the least significant part of the address. More than one logical block may be 
described by this descriptor. 


SCSI Commands Reference Manual, Rev. A 


69 




3.6 


INQUIRY command 


3.6.1 INQUIRY command introduction 

The INQUIRY command (see table 45) requests that information regarding the logical unit and SCSI target 
device be sent to the application client. 

Table 45 — INQUIRY command 


Bit 

Byte 

7 6 5 4 3 2 

1 

0 

0 

OPERATION CODE (12h) 

1 

Reserved 

Obsolete 

Formerly 

CMDDT 

EVPD 

2 

PAGE CODE 

3 

(MSB) ALLOCATION LENGTH 



4 


(LSB) 

5 

CONTROL 


EVPD (Enable Vital Product Data) bit 

An enable vital product data (EVPD) bit set to one specifies that the device server shall return the vital product 
data specified by the PAGE CODE field (see 3.6.4). 

0 If the EVPD bit is set to zero, the device server shall return the standard INQUIRY data (see 3.6.2). If the PAGE 
CODE field is not set to zero when the EVPD bit is set to zero, the command shall be terminated with CHECK CON¬ 
DITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD 
INCDB. 

1 When the EVPD bit is set to one, the PAGE CODE field specifies which page of vital product data information the 
device server shall return (see 4.4). 

CMDDT (Command Support Data) bit 

This bit has been declared Obsolete by T10. See SBC-2 for a description of this bit. 

If both the EVPD and CMDDT bits are one, the target shall return CHECK CONDITION status with the sense key set to 
ILLEGAL REQUEST and an additional sense code of Invalid Field in CDB. When the EVPD bit is one, the Page or OPER¬ 
ATION CODE field specifies which page of vital product data information the target shall return. 

ALLOCATION LENGTH field 

The ALLOCATION LENGTH field is defined in 2.1.4.5. If EVPD is set to zero, the allocation length should be at least five, so 
that the ADDITIONAL LENGTH field in the parameter data (see 3.6.2) is returned. If EVPD is set to one, the allocation 
length should be should be at least four, so that the PAGE LENGTH field in the parameter data (see 4.4) is returned. 

In response to an INQUIRY command received by an incorrect logical unit, the SCSI target device shall return 
the INQUIRY data with the peripheral qualifier set to the value defined in 3.6.2. The INQUIRY command shall 
return CHECK CONDITION status only when the device server is unable to return the requested INQUIRY 
data. 

If an INQUIRY command is received from an initiator port with a pending unit attention condition (i.e., before 
the device server reports CHECK CONDITION status), the device server shall perform the INQUIRY command 
and shall not clear the unit attention condition (see SAM-3). 
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The INQUIRY data should be returned even though the device server is not ready for other commands. The 
standard INQUIRY data should be available without incurring any media access delays. If the device server 
does store some of the standard INQUIRY data or VPD data on the media, it may return ASCII spaces (20h) in 
ASCII fields and zeros in other fields until the data is available from the media. 

The INQUIRY data may change as the SCSI target device and its logical units perform their initialization 
sequence. (E.g., logical units may provide a minimum command set from nonvolatile memory until they load 
the final firmware from the media. After the firmware has been loaded, more options may be supported and 
therefore different INQUIRY data may be returned.) 

If the INQUIRY data changes for any reason, the device server shall establish a unit attention condition for the 
initiator port associated with every l_T nexus (see SAM-3), with the additional sense code set to INQUIRY 
DATA HAS CHANGED. 

The INQUIRY command may be used by an application client after a hard reset or power on condition to deter¬ 
mine the device types for system configuration. 
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3.6.2 Standard INQUIRY data 

The standard INQUIRY data (see table 46) shall contain at least 36 bytes 

Table 46 — Standard INQUIRY data format 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

PERIPHERAL QUALIFIER PERIPHERAL DEVICE TYPE 

1 

RMB Reserved 

2 

VERSION 

3 

Obsolete Obsolete NORMACA HISUP RESPONSE DATA FORMAT 

4 

ADDITIONAL LENGTH (N-4) 

5 

SCCS ACC TPGS 3PC Reserved PROTECT 

6 

BQUE ENCSERV VS MULTIP MCHNGR Obsolete Obsolete ADDR16 a 

7 

Obsolete Obsolete WBUS16a a SYNC a LINKED Obsolete CMDQUE VS 

8 

(MSB) T10 VENDOR IDENTIFICATION 

15 

(LSB) 

16 

(MSB) PRODUCT IDENTIFICATION 

31 

(LSB) 

32 

(MSB) PRODUCT REVISION LEVEL 

35 

(LSB) 

36 

DRIVE SERIAL NUMBER 

43 


44 

Vendor Unique 

55 

Seagate fills this field with OOh. 

56 

Reserved CLOCKING a QAS a IUS a 

57 

Reserved 

58 

(MSB) VERSION DESCRIPTOR 1 

59 

(LSB) 
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(MSB) VERSION DESCRIPTOR 8 

73 

(LSB) 

74 

Reserved 

95 



Vendor specific parameters 
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Table 46 — Standard INQUIRY data format 


Bit 

Byte 

7 6 5 4 3 2 1 0 

96 

Copyright Notice (Vendor specific) 

n 


a The meanings of these fields are specific to SPI-5 (see 3.6.3). For SCSI transport protocols other than the 
SCSI Parallel Interface, these fields are reserved. 


PERIPHERAL QUALIFIER and PERIPHERAL DEVICE TYPE fields 

The PERIPHERAL QUALIFIER field and PERIPHERAL DEVICE TYPE field identify the peripheral device connected to the 
logical unit. If the SCSI target device is not capable of supporting a peripheral device connected to this logical unit, the 
device server shall set these fields to 7Fh (i.e., PERIPHERAL QUALIFIER field set to 011b and PERIPHERAL DEVICE 
TYPE field set tolFh). 

The peripheral qualifier is defined in table 47 and the peripheral device type is defined in table 48. 


Table 47 — PERIPHERAL QUALIFIER 


Qualifier 

Description 

000b 

A peripheral device having the specified peripheral device type is connected to this logical unit. If the 
device server is unable to determine whether or not a peripheral device is connected, it also shall use 
this peripheral qualifier. This peripheral qualifier does not mean that the peripheral device connected 
to the logical unit is ready for access. 

001b 

A peripheral device having the specified peripheral device type is not connected to this logical unit. 
However, the device server is capable of supporting the specified peripheral device type on this logi¬ 
cal unit. 

010b 

Reserved 

011b 

The device server is not capable of supporting a peripheral device on this logical unit. For this periph¬ 
eral qualifier the peripheral device type shall be set to 1 Fh. All other peripheral device type values are 
reserved for this peripheral qualifier. 

100b-111b 

Vendor specific 
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Table 48. PERIPHERAL DEVICE TYPE 


Code 

Doc. a 

Description 

OOh 

SBC-2 

Direct access block device (e.g., magnetic disk) 

Olh 

SSC-2 

Sequential-access device (e.g., magnetic tape) 

02h 

SSC 

Printer device 

03h 

SPC-2 

Processor device 

04h 

SBC 

Write-once device (e.g., some optical disks) 

05h 

MMC-4 

CD/DVD device 

06h 


Scanner device (obsolete) 

07h 

SBC 

Optical memory device (e.g., some optical disks) 

08h 

SMC-2 

Medium changer device (e.g., jukeboxes) 

09h 


Communications device (obsolete) 

OAh - OBh 


Obsolete 

OCh 

SCC-2 

Storage array controller device (e.g., RAID) 

ODh 

SES 

Enclosure services device 

OEh 

RBC 

Simplified direct-access device (e.g., magnetic disk) 

OFh 

OCRW 

Optical card reader/writer device 

lOh 

BCC 

Bridge Controller Commands 

11 h 

OSD 

Object-based Storage Device 

12h 

ADC 

Automation/Drive Interface 

13h-IDh 


Reserved 

1 Eh 


Well known logical unit b 

1 Fh 


Unknown or no device type 

a All standards are subject to revision, and parties to agreements based on the standard are encouraged to investigate 
the possibility of applying the most recent editions of the listed standards. 

b All well known logical units use the same peripheral device type code. 


RMB (Removable Media) bit 

0 A removable medium (RMB) bit set to zero indicates that the medium is not removable. 
1 A RMB bit set to one indicates that the medium is removable. 
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VERSION field 


The VERSION field indicates the implemented version of the standard and is defined in table 49. 

Table 49. VERSION field codes 


Code 

Description 

OOh 

The device does not claim conformance to any standard. 


02h 

Obsolete 



03h 

The device complies to ANSI INCITS 301-1997 (SPC). 


04 h 

The device complies to ANSI INCITS 351-2001 (SPC-2). 


05h 

The device complies to the standard. 



Code 

Description 

Code 

Description 

01 h 

Obsolete (SCSI=001b) 

06h - 07h 

Reserved 

08h-OCh 

Obsolete (ECMA=001b) 

ODh-3Fh 

Reserved 

40h - 44h 

Obsolete (ISO=01b) 

45h - 47h 

Reserved 

48h-4Ch 

Obsolete (ISO=01b & ECMA=001b) 

4Dh - 7Fh 

Reserved 

80h - 84h 

Obsolete (ISO=10b) 

85h - 87h 

Reserved 

88h-8Ch 

Obsolete (ECMA=001b) 

8Dh-FFh 

Reserved 


NORMACA (Normal ACA Supported 

1 The Normal ACA Supported (NORMACA) bit set to one indicates that the device server supports a NACA bit set to 
one in the CDB control byte and supports the ACA task attribute (see SAM-3). 

0 A NORMACA bit set to zero indicates that the device server does not support a NACA bit set to one and does not 
support the ACA task attribute. 

HISUP (Hierarchical Support) bit 

0 A hierarchical support (HISUP) bit set to zero indicates the SCSI target device does not use the hierarchical 
addressing model to assign LUNs to logical units. 

1 A HISUP bit set to one indicates the SCSI target device uses the hierarchical addressing model to assign LUNs to 
logical units. 

RESPONSE DATA FORMAT field 

A RESPONSE DATA FORMAT field value of two indicates that the data shall be in the format defined in the standard. 

Response data format values less than two are obsolete. Response data format values greater than two are reserved. 

ADDITIONAL LENGTH field 

The ADDITIONAL LENGTH field indicates the length in bytes of the remaining standard INQUIRY data. The relationship 

between the ADDITIONAL LENGTH field and the CDB ALLOCATION LENGTH field is defined in 2.1.4.5. 

SCCS (SCC Supported) bit 

1 An SCC Supported (SCCS) bit set to one indicates that the SCSI target device contains an embedded storage array 
controller component. See SCC-2 for details about storage array controller devices. 

0 An SCCS bit set to zero indicates that the SCSI target device does not contain an embedded storage 
array controller component. 

ACC (Access Controls Coordinator) bit 

1 An Access Controls Coordinator (ACC) bit set to one indicates that the SCSI target device contains an access con¬ 
trols coordinator that may be addressed through this logical unit. 
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0 An ACC bit set to zero indicates that no access controls coordinator may be addressed through this logical unit. If 
the SCSI target device contains an access controls coordinator that may be addressed through any logical unit 
other than the ACCESS CONTROLS well known logical unit, then the ACC bit shall be set to one for LUN 0. 

TPGS (Target Port Group Support) field 

The contents of the target port group support (TPGS) field (see table 50) indicate the support for asymmetric logical unit 
access. 


Table 50. Taret Port GroupSupport codes 


Code 

Description 

00b 

The SCSI target device does not support asymmetric logical unit access or supports a form of asymmetric 
access that is vendor specific. Neither the REPORT TARGET GROUPS nor the SET TARGET GROUPS com¬ 
mands is supported. 

01b 

Only implicit asymmetric logical unit access (see SPC-4 clause 5.8.2.7) is supported. The SCSI target device 
is capable of changing target port asymmetric access states without a SET TARGET PORT GROUPS com¬ 
mand. The REPORT TARGET PORT GROUPS command is supported and the SET TARGET PORT 

GROUPS command is not supported. 

10b 

Only explicit asymmetric logical unit access (i.e., the TPGS field contains 10b or 11 b) is supported. The SCSI 
target device only changes target port asymmetric access states as requested with the SET TARGET PORT 
GROUPS command. Both the REPORT TARGET PORT GROUPS command and the SET TARGET PORT 
GROUPS command are supported. 

11b 

Both explicit and implicit asymmetric logical unit access are supported. Both the REPORT TARGET PORT 
GROUPS command and the SET TARGET PORT GROUPS commands are supported. 


3PC (Third-Party Copy) bit 

1 A Third-Party Copy (3PC) bit set to one indicates that the SCSI target device supports third-party copy commands 
such as the EXTENDED COPY command. 

0 A 3PC bit set to zero indicates that the SCSI target device does not support such commands. 

PROTECT bit 

0 A PROTECT bit set to zero indicates that the logical unit does not support protection information (i.e. type 0) (see 
SPC-4 7.6.4 and SBC-3). 

1 A PROTECT bit set to one indicates that the logical unit supports type 1 protection, type 2 protection, or type 3 pro¬ 
tection (see SBC-3). The SPT field (see 4.4.5) indicates which type of protection the logical unit supports. 

BQUE (Basic Queuing) bit 

The BQUE bit combines with the CMDQUE bit to indicate whether the logical unit supports the full task management model 

or the basic task management model as described in table 51. 

ENCSERV (Enclosure Services) bit 

1 An Enclosure Services (ENCSERV) bit set to one indicates that the SCSI target device contains an embedded 
enclosure services component. See SES for details about enclosure services, including a device model for an 
embedded enclosure services device. 

0 An ENCSERV bit set to zero indicates that the SCSI target device does not contain an embedded enclosure ser¬ 
vices component. 

MULTIP (Multi Port) bit 

1 A Multi Port (MULTIP) bit set to one indicates that this is a multi-port (two or more ports) SCSI target device and 
conforms to the SCSI multi-port device requirements found in the applicable standards (e.g., SAM-3, a SCSI trans¬ 
port protocol standard and possibly provisions of a command standard). 

0 A MULTIP bit set to zero indicates that this SCSI target device has a single port and does not implement the multi- 
port requirements. 
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MCHNGR (Medium Changer) bit 

1 A medium changer (MCHNGR) bit set to one indicates that the SCSI target device supports commands to control an 
attached media changer. See SMC-2 for details about medium changers, including a device model for an attached 
medium changer device. The MCHNGR bit is valid only when the RMB bit is equal to one. 

0 A MCHNGR bit set to zero indicates that the SCSI target device does not support commands to control an attached 
media changer. 

LINKED (Linked Command) bit 

1 A linked command (LINKED) bit set to one indicates that the device server supports linked commands (see SAM-3). 

0 A LINKED bit set to zero indicates the device server does not support linked commands. 

CMDQUE (Command Queuing) bit 

The CMDQUE bit and BQUE bit indicate whether the logical unit supports the full task management model (see SAM-3) or 

the basic task management model (see SAM-3) as described in table 51. 

Table 51. BQue and CmdQue bit combinations 


BQue 

CmdQue 

Description 

0 

0 

Obsolete 

0 

1 

Full task management model supported 

1 

0 

Basic task management model supported 

1 

1 

Illegal combination of BQUE and CMDQUE bits 


VENDOR IDENTIFICATION field 

The T10 VENDOR IDENTIFICATION field contains eight bytes of left-aligned ASCII data (see 4.4.2) identifying the vendor 
of the product. The T10 vendor identification shall be one assigned by INCITS. Bytes 8 through 15 contain the ASCII char¬ 
acters thet represent “SEAGATE ” (53h 45h 41 h 47h 41 h 54h 45h 20h (space)). 


PRODUCT IDENTIFICATION 


The PRODUCT IDENTIFICATION field contains sixteen bytes of left-aligned ASCII data (see 4.4.2) defined by Seagate. 
Bytes 16 through 31 indicate the drive model with 20h (space) used as a filler. The table below is and example of drive test 
data returned by the drive. Bytes 16 and 17 will contain 53 54 for all drive models. 


Bte 18 throught 26 values that may be returned by a Seagate 15K5 parallel SCSI drive: 


ST3300655LW 

ST3300655LC 

ST3146855LW 

ST3146855LC 

ST373455LW 

ST373455LC 


53 54 33 33 
53 54 33 33 
53 54 33 31 
53 54 33 31 
53 54 33 37 
53 54 33 37 


30 30 36 
30 30 36 
35 36 38 
35 36 38 
33 34 35 
33 34 35 


35 35 4C 57 
35 35 4C 43 
35 35 4C 57 
35 35 4C 43 
35 4C 57 20 
35 4C 43 20 


Refer to the applicable Seagate product manual to get the actual test string. 


PRODUCT REVISION LEVEL field 

The PRODUCT REVISION LEVEL field contains four bytes of left-aligned ASCII data defined by Seagate. Bytes 32 
through 35 contain the four ASCII digits representing the last four digits of the product Firmware Release number. This 
information is also given in the Vital Product Data page COh, together with servo RAM and ROM release numbers. 


VERSION DESCRIPTOR fields 

The VERSION DESCRIPTOR fields provide for identifying up to eight standards to which the SCSI target device claims 
conformance. The value in each VERSION DESCRIPTOR field shall be selected from the Version Descriptor Values Table 
in the current SPC standard. All version descriptor values not listed in table 52 are reserved. Technical Committee T10 of 
INCITS maintains an electronic copy of the information in the Version Descriptor Values Table on its world wide web site 
(http://www.t10.org/). In the event that the T10 world wide web site is no longer active, access may be possible via the 
INCITS world wide web site (http://www.incits.org), the ANSI world wide web site (http://www.ansi.org), the IEC site (http:// 
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www.iec.ch/), the ISO site (http://www.iso.ch/), or the ISO/IEC JTC 1 web site (http://www.jtd .org/). It is recommended that 
the first version descriptor be used for the SCSI architecture standard, followed by the physical transport standard if any, 
followed by the SCSI transport protocol standard, followed by the appropriate SPC version, followed by the device type 
command set, followed by a secondary command set if any. Refer to the latest SPC version for a complete list of descriptor 
values. 

Copyright Notice field 

Seagate uses bytes 96 - 143 to provide a copyright notice that begins “Copyright (c) XXXX Seagate All rights reserved,” 
where “XXXX” indicates the year the drive’s firmware code was built (for example: 2005). 

3.6.3 SCSI Parallel Interface specific INQUIRY data 

Portions of bytes 6 and 7 and all of byte 56 of the standard INQUIRY data shall be used only by SCSI target 
devices that implement the SCSI Parallel Interface. These fields are noted in table 46. For details on how the 
SPI-specific fields relate to the SCSI Parallel Interface see SPI-n (where n is 2 or greater). Table 52 shows just 
the SPI-specific standard INQUIRY fields. The definitions of the SCSI Parallel Interface specific fields shall be 
as follows. 


Table 52 — SPI-specific standard INQUIRY bits 


Bit 

Byte 

7 6 5 4 3 2 1 

0 

6 

SEE table 46 

ADDR16 

7 

SEE table 46 WBUS16 SYNC SEE table 46 Obsolete SEE table 46 



56 

Reserved CLOCKING QAS IUS 


ADDR16 (wide SCSI address 16) bit 

1 A wide SCSI address 16 (ADDR16) bit of one indicates that the SCSI target device supports 16-bit wide SCSI 
addresses. 

0 A value of zero indicates that the SCSI target device does not support 16-bit wide SCSI addresses. 

WBUS16 (wide bus 16) bit 

1 A wide bus 16 (WBUS16) bit of one indicates that the SCSI target device supports 16-bit wide data transfers. 

0 A value of zero indicates that the SCSI target device does not support 16-bit wide data transfers. 

SYNC (synchronous transfer) bit 

1 A synchronous transfer (SYNC) bit of one indicates that the SCSI target device supports synchronous data transfer. 
0 A value of zero indicates the SCSI target device does not support synchronous data transfer. 

The obsolete bit 2 in byte 7 indicates whether the SCSI target device supports an obsolete data transfers man¬ 
agement mechanism defined in SPI-2. 
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Table 53 defines the relationships between the addr16 and wbus16 bits. 

Table 53. ADDR and WBUS bit relationships 


addr16 wbus16 

Description 

0 0 

0 1 

1 1 

8 bit wide data path on a single cable with 8 SCSI IDs supported 

16 bit wide data path on a single cable with 8 SCSI IDs supported 

16 bit wide data path on a single cable with 16 SCSI IDs supported 


CLOCKING field 

The CLOCKING field shall not apply to asynchronous transfers and is defined in table 54. 


Table 54. 

CLOCKING codes 

Code 

Description 

00b 

Indicates the target port supports only ST 

01b 

Indicates the target port supports only DT 

10b 

Reserved 

11b 

Indicates the target port supports ST and DT 


QAS (Quick Arbitration And Selection Supported) bit 

1 A quick arbitration and selection supported (QAS) bit of one indicates that the target port supports quick arbitration 
and selection. 

0 A value of zero indicates that the target port does not support quick arbitration and selection. 

IUS (information units supported) bit 

1 An information units supported (IUS) bit of one indicates that the SCSI target device supports information unit trans¬ 
fers. 

0 A value of zero indicates that the SCSI target device does not support information unit transfers. 

The acronyms ST and DT and the terms 'quick arbitration and selection' and 'information units' are defined in 
SPI-5. 


3.6.4 Vital product data 

The application client requests the vital product data information by setting the EVPD bit to one and specifying 
the page code of a vital product data. See 4.4 for details about vital product data. The information returned con¬ 
sists of configuration data (e.g., vendor identification, product identification, model, serial number), manufactur¬ 
ing data (e.g., plant and date of manufacture), field replaceable unit data and other vendor specific or device 
specific data. If the device server does not implement the requested page, the command shall be terminated 
with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code 
set to INVALID FIELD IN CDB. 

The device server should have the ability to process the INQUIRY command even when an error occurs that 
prohibits normal command completion. In such a case, CHECK CONDITION status should be returned for 
commands other than INQUIRY or REQUEST SENSE. The sense data returned may contain the field replace¬ 
able unit code. The vital product data may be obtained for the failing device using the INQUIRY command. 

the standard defines a format that allows device-independent application client software to display the vital 
product data returned by the INQUIRY command. The contents of the data may be vendor specific, and may 
be unusable without detailed information about the device. 
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the standard does not define the location or method of storing the vital product data. The retrieval of the data 
may require completion of initialization operations within the device, that may induce delays before the data is 
available to the application client. Time-critical requirements are an implementation consideration and are not 
addressed in the standard. 

3.7 LOCK-UNLOCK Cache (10) command 

Obsolete. If received, a CHECK CONDITION status is sent. 

3.8 LOCK-UNLOCK Cache (16) command 

Obsolete. If received, a CHECK CONDITION status is sent. 
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3.9 


LOG SELECT command 


The LOG SELECT command (see table 55) provides a means for an application client to manage statistical 
information maintained by the SCSI target device about the SCSI target device or its logical units. Device serv¬ 
ers that implement the LOG SELECT command shall also implement the LOG SENSE command. Structures in 
the form of log parameters within log pages are defined as a way to manage the log data. The LOG SELECT 
command provides for sending zero or more log pages via the Data-Out Buffer. This manual defines the format 
of the log pages, but does not define the conditions and events that are logged. 

Table 55 — LOG SELECT command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (4Ch) 

1 

Reserved PCR SP 

2 

PC Reserved 

3 

Reserved 

4 


5 

(MSB) PARAMETER LIST LENGTH 

6 

(LSB) 

7 

CONTROL 


PCR (Parameter Code Reset) bit 

1 A Parameter Code Reset (PCR) bit set to one and a parameter list length of zero shall cause all implemented 
parameters to be set to Seagate specific default values (e.g., zero). If the PCR bit is set to one and the parameter 
list length is greater than zero, the command shall be terminated with CHECK CONDITION status, with the sense 
key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 

0 A PCR bit set to zero specifies that the log parameters shall not be reset. 

SP (Save Parameters) bit 

1 A save parameters (SP) bit set to one specifies that after performing the specified LOG SELECT operation the 
device server shall save to nonvolatile memory all parameters identified as saveable by the DS bit in the log page. 

0 A SP bit set to zero specifies that parameters shall not be saved. 

Saving of log parameters is optional and indicated for each log parameter by the DS bit in the log page. Log 
parameters also may be saved at vendor specific times subject to the TSD bit in the log parameter and the 
GLTSD bit in the Control mode page. If the logical unit does not implement saved parameters for any log 
parameter and the SP bit is set to one, the command shall be terminated with CHECK CONDITION status, with 
the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 

It is not an error to set the SP bit to one and to set the DS bit of a log parameter to one. In this case, the param¬ 
eter value for that log parameter is not saved. 
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PC (Page Control) field 

The Page Control (PC) field defines the type of parameter values to be selected. The PC field is defined in table 56. 

Table 56. Page Control field values 


PC 

LOG SELECT parameter values 

LOG SENSE parameter values 

00b 

Current threshold values 

Threshold values 

01b 

Current cumulative values 

Cumulative values 

10b 

Default threshold values 

Default threshold values 

11b 

Default cumulative values 

Default cumulative values 


The current cumulative values may be updated by the device server or by the application client using the LOG SELECT 
command to reflect the cumulative number of events experienced by the logical unit. Fields in the parameter control byte of 
each log parameter control the updating and saving of the current cumulative parameters. 

The device server shall set the current threshold parameters to the default threshold values in response to a LOG SELECT 
command with the PC field set to 10b and the parameter list length field set to zero. 

The device server shall set all cumulative parameters to their default values in response to a LOG SELECT command with 
the PC field set to 11 b and the parameter list length field set to zero. 

The current threshold value may only be modified by the application client via the LOG SELECT command. If the applica¬ 
tion client attempts to change current threshold values that are not available or not implemented for that log parameter, 
then the device server shall terminate the LOG SELECT command with CHECK CONDITION status, with the sense key set 
to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. The saving of current 
threshold parameters and the criteria for the current threshold being met are controlled by bits in the parameter control 
byte. 

Note. Log pages or log parameters that are not available may become available at some later time (e.g., 
after the logical unit has become ready). 

PARAMETER LIST LENGTH field 

The PARAMETER LIST LENGTH field specifies the length in bytes of the parameter list that shall be located in the 
Data-Out Buffer. A parameter list length of zero specifies that no log pages shall be transferred. This condition shall not be 
considered an error. If an application client sends page codes or parameter codes within the parameter list that are 
reserved or not implemented by the logical unit, then the device server shall terminate the LOG SELECT command with 
CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID 
FIELD IN PARAMETER LIST. 

If a parameter list length results in the truncation of any log parameter, the device server shall terminate the command with 
CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST. The additional sense code should be set to 
PARAMETER LIST LENGTH ERROR or may be set to INVALID FIELD IN CDB. 

The application client should send log pages in ascending order by page code value if the Data-Out Buffer contains multiple 
log pages. If the Data-Out Buffer contains multiple log parameters within a log page, then they should be sent in ascending 
order by parameter code value. If the application client sends log pages out of order or parameter codes out of order, the 
command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the 
additional sense code set to INVALID FIELD IN PARAMETER LIST. 


Application clients should issue LOG SENSE commands prior to issuing LOG SELECT commands to deter¬ 
mine supported log pages and page lengths. 

The SCSI target device may provide independent sets of log parameters for each logical unit or for each com¬ 
bination of logical units and l_T nexuses. If the SCSI target device does not support independent sets of log 
parameters and any log parameters are changed that affect other l_T nexuses, then the device server shall 
establish a unit attention condition (see SAM-3) for the initiator port associated with every l_T nexus except the 
I T nexus on which the LOG SELECT command was received, with the additional sense code set to LOG 
PARAMETERS CHANGED. 
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If an application client sends a log parameter that is not supported by the logical unit, the command shall be 
terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional 
sense code set to INVALID FIELD IN PARAMETER LIST 

Additional information about the LOG SELECT command is in SPC-4. 
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3.10 


LOG SENSE command 


The LOG SENSE command (see table 57) provides a means for the application client to retrieve statistical or 
other operational information maintained by the SCSI target device about the SCSI target device or its logical 
units. It is a complementary command to the LOG SELECT command. See clause 4.2 of this manual for more 
information on returned log pages. 


Table 57 — LOG SENSE command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (4Dh) 

1 

Reserved PPC SP 

2 

PC PAGE CODE 

3 

Reserved 

4 


5 

(MSB) PARAMETER POINTER 

6 

(LSB) 

7 

(MSB) ALLOCATION LENGTH 

8 

(LSB) 

9 

CONTROI 


PPC (Parameter Pointer Control) bit 

The parameter pointer control (PPC) bit controls the type of parameters requested from the device server: 

1 A PPC bit set to one specifies that the device server shall return a log page with parameter code values that have 
changed since the last LOG SELECT or LOG SENSE command. The device server shall return only those parame¬ 
ter codes that are greater than or equal to the contents of the PARAMETER POINTER field in ascending order of 
parameter codes from the specified log page; 

0 A PPC bit set to zero specifies that the device server shall return those parameter codes that are greater than or 
equal to the contents of the PARAMETER POINTER field in ascending order of parameter codes from the specified 
log page; and 

0 A PPC bit set to zero and a PARAMETER POINTER field set to zero specifies that the device server shall return all 
available log parameters from the specified log page. 

SP (Saving Parameters) bit 

1 Saving parameters is an optional function of the LOG SENSE command. If the logical unit does not implement sav¬ 
ing log parameters and if the save parameters (SP) bit is set to one, then the command shall be terminated with 
CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to 
INVALID FIELD IN CDB. 

0 An SP bit set to zero specifies the device server shall perform the specified LOG SENSE command and shall not 
save any log parameters. If saving log parameters is implemented, an SP bit set to one specifies that the device 
server shall perform the specified LOG SENSE command and shall save all log parameters identified as saveable 
by the DS bit to a nonvolatile, vendor specific location. 

PC (Page Control) field 

The page control (PC) field specifies the type of parameter values to be selected (see 3.9 for the definition of the page con¬ 
trol field). The parameter values returned by a LOG SENSE command are determined as follows: 

a) The specified parameter values at the last update (i.e., in response to a LOG SELECT or LOG SENSE com- 
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mand or done automatically by the device server for cumulative values); 

b) The saved values, if saved parameters are implemented and an update has not occurred since the last logical 
unit reset; or 

c) The default values, if saved values are not available or not implemented and an update has not occurred since 
the last logical unit reset. 

PAGE CODE Field 

The PAGE CODE field specifies which log page of data is being requested. If the log page code is reserved or not imple¬ 
mented, the command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL 
REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 

PARAMETER POINTER field 

The PARAMETER POINTER field allows the application client to request parameter data beginning from a specific param¬ 
eter code to the maximum allocation length or the maximum parameter code supported by the logical unit, whichever is 
less. If the value of the PARAMETER POINTER field is larger than the largest available parameter code known to the 
device server for the specified log page, the command shall be terminated with CHECK CONDITION status, with the sense 
key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 

ALLOCATION LENGTH field 

The ALLOCATION LENGTH field is defined in 2.1.4.5. 

Log parameters within the specified log page shall be transferred in ascending order according to parameter 
code. 

Additional information about the LOG SENSE command is in SPC-4 Annex C. 
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3.11 MODE SELECT(6) command 

The MODE SELECT(6) command (see table 58) provides a means for the application client to specify medium, 
logical unit, or peripheral device parameters to the device server. Device servers that implement the MODE 
SELECT(6) command shall also implement the MODE SENSE(6) command. Application clients should issue 
MODE SENSE(6) prior to each MODE SELECT(6) to determine supported mode pages, page lengths, and 
other parameters. 


Table 58 — MODE SELECT(6) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (15h) 

1 

Reserved PF Reserved SP 

2 

Reserved 

3 


4 

PARAMETER LIST LENGTH 

5 

CONTROL 


Logical units shall share mode parameter header and block descriptor values across all l_T nexuses. I_T 
nexus loss shall not affect mode parameter header, block descriptor, and mode page values. 

Logical units shall maintain current and saved values of each mode page based on any of the policies listed in 
table 59. The mode page policy used for each mode page may be reported in the Mode Page Policy VPD page 
(see SPC-4 7.6.6). 


Table 59 — Mode page policies 


Mode page policy 

Number of mode page copies 

Shared 

One copy of the mode page that is shared by all l_T nexuses. 

Per target port 

A separate copy of the mode page for each target port with each copy shared by all initia¬ 
tor ports. 

Per l_T nexus 

A separate copy of the mode page for each l_T nexus 


After a logical unit reset, each mode parameter header, block descriptor, and mode page shall revert to saved 
values if supported or default values if saved values are not supported. 

If an application client sends a MODE SELECT command that changes any parameters applying to other l_T 
nexuses, the device server shall establish a unit attention (see SAM-3) condition for the initiator port associ¬ 
ated with every I T nexus except the l_T nexus on which the MODE SELECT command was received, with the 
additional sense code set to MODE PARAMETERS CHANGED. 

PF (Page Format) bit 

0 A page format (PF) bit set to zero specifies that all parameters after the block descriptors are vendor specific. 

1 A PF bit set to one specifies that the MODE SELECT parameters following the header and block descriptor(s) are 

structured as pages of related parameters and are as defined in the standard. 

SP (save pages) bit 

0 A save pages (SP) bit set to zero specifies that the device server shall perform the specified MODE SELECT oper¬ 
ation, and shall not save any mode pages. If the logical unit implements no distinction between current and saved 
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mode pages and the SP bit is set to zero, the command shall be terminated with CHECK CONDITION status, with 
the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. An SP bit 
set to one specifies that the device server shall perform the specified MODE SELECT operation, and shall save to a 
nonvolatile vendor specific location all the saveable mode pages including any sent in the Data-Out Buffer. Mode 
pages that are saved are specified by the parameter saveable (PS) bit that is returned in the first byte of each mode 
page by the MODE SENSE command. 

1 If the PS bit is set to one in the MODE SENSE data, then the mode page shall be saveable by issuing a MODE 
SELECT command with the SP bit set to one. If the logical unit does not implement saved mode pages and the SP 
bit is set to one, then the command shall be terminated with CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 

PARAMETER LIST LENGTH field 

The PARAMETER LIST LENGTH field specifies the length in bytes of the mode parameter list that shall be contained in the 
Data-Out Buffer. A parameter list length of zero specifies that the Data-Out Buffer shall be empty. This condition shall not be 
considered as an error. 

If the parameter list length results in the truncation of any mode parameter header, mode parameter block descriptor(s), or 
mode page, then the command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL 
REQUEST, and the additional sense code set to PARAMETER LIST LENGTH ERROR. 

The mode parameter list for the MODE SELECT and MODE SENSE commands is defined in 3.13. Parts of each mode 
parameter list are defined in a device-type dependent manner. Definitions for the parts of each mode parameter list that are 
unique for each device-type may be found in the applicable command standards. 

The device server shall terminate the MODE SELECT command with CHECK CONDITION status, set the sense key to 
ILLEGAL REQUEST, set the additional sense code to INVALID FIELD IN PARAMETER LIST, and shall not change any 
mode parameters in response to any of the following conditions: 

a) If the application client sets any field that is reported as not changeable by the device server to a value other 
than its current value; 

b) If the application client sets any field in the mode parameter header or block descriptor(s) to an unsupported 
value; 

c) If an application client sends a mode page with a page length not equal to the page length returned by the 
MODE SENSE command for that mode page; 

d) If the application client sends an unsupported value for a mode parameter and rounding is not implemented for 
that mode parameter; or 

e) If the application client sets any reserved field in the mode parameter list to a non-zero value and the device 
server checks reserved fields. 

If the application client sends a value for a mode parameter that is outside the range supported by the device server and 
rounding is implemented for that mode parameter, the device server handles the condition by either: 

a) Rounding the parameter to an acceptable value and terminating the command as described in the current ver¬ 
sion of the SPC standard; or 

b) Terminating the command with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, 
and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 

A device server may alter any mode parameter in any mode page, even those reported as non-changeable, as a result of 
changes to other mode parameters. 

The device server validates the non-changeable mode parameters against the current values that existed for those mode 
parameters prior to the MODE SELECT command. 

Note. The current values calculated by the device server may affect the application client's operation. The 
application client may issue a MODE SENSE command after each MODE SELECT command, to 
determine the current values. 
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3.12 MODE SELECT(IO) command 

The MODE SELECT(IO) command (see table 60) provides a means for the application client to specify 
medium, logical unit, or peripheral device parameters to the device server. See the MODE SELECT(6) com¬ 
mand (3.9) for a description of the fields and operation of this command. Application clients should issue 
MODE SENSE(IO) prior to each MODE SELECT(IO) to determine supported mode pages, page lengths, and 
other parameters. Device servers that implement the MODE SELECT(IO) command shall also implement the 
MODE SENSE(IO) command. 


Table 60 — MODE SELECT(IO) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (55h) 

1 

Reserved PF Reserved SP 

2 

Reserved 

3 


4 

(MSB) PARAMETER LIST LENGTH 

5 

(LSB) 

6 

CONTROL 
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3.13 


MODE SENSE(6) command 


3.13.1 MODE SENSE(6) command introduction 

The MODE SENSE(6) command (see table 61) provides a means for a device server to report parameters to 
an application client. It is a complementary command to the MODE SELECT(6) command. Device servers that 
implement the MODE SENSE(6) command shall also implement the MODE SELECT(6) command. 

Table 61 — MODE SENSE(6) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (1 Ah) 

1 

Reserved DBD Reserved 

2 

PC PAGE CODE 

3 

SUBPAGE CODE 

4 

ALLOCATION LENGTH 

5 

CONTROL 


DBD (disable block descriptors) bit 

0 A disable block descriptors (DBD) bit set to zero specifies that the device server may return zero or more block 
descriptors in the returned MODE SENSE data. 

1 A DBD bit set to one specifies that the device server shall not return any block descriptors in the returned MODE 
SENSE data. 

PC (Page Control) field 

The page control (PC) field specifies the type of mode parameter values to be returned in the mode pages. The PC field is 
defined in table 62. 

Table 62 — Page control (PC) field 


Code 

Type of parameter 

Reference 

00b 

Current values 

3.13.1.1 

01b 

Changeable values 

3.13.1.2 

10b 

Default values 

3.13.1.3 

11b 

Saved values 

3.13.1.4 


The PC field only affects the mode parameters within the mode pages, however the PS bit, SPF bit, PAGE CODE field, 
SUBPAGE CODE field, and PAGE LENGTH field should return current values (i.e., as if PC is set to 00b). The mode 
parameter header and mode parameter block descriptor should return current values. 

Some SCSI target devices may not distinguish between current and saved mode parameters and report identi¬ 
cal values in response to a PC field of either 00b or 11b. See also the description of the save pages (SP) bit in 
the MODE SELECT command. 
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PAGE CODE and SUBPAGE CODE fields 

The PAGE CODE and SUBPAGE CODE fields specify which mode pages and subpages to return (see table 63). 

Table 63 — Mode page code usage for all devices 


Page Code 

Subpage Code 

Description 

OOh 

vendor specific 

Vendor specific (does not require page format) 

01 h -1 Fh 

OOh 

See specific device types (page_0 format) 

01 h- DFh 

See specific device types (sub page format) 

EOh - FEh 

Vendor specific (sub_page format) 

FFh 

Return all subpages for the specified device specific mode page in the 
page 0 format for subpage OOh and in the sub page format for subpages 

01 h - FEh 

20h-3Eh 

OOh 

Vendor specific (page_0 format required) 

01 h - FEh 

Vendor specific (sub_page format required) 

FFh 

Return all subpages for the specified vendor specific mode page in the 
page_0 format for subpage OOh and in the sub page format for subpages 

01 h - FEh 

3Fh 

OOh 

Return all subpage OOh mode pages in page_0 format 

01 h - FEh 

Reserved 

FFh 

Return all subpages for all mode pages in the page_0 format for subpage 
OOh and in the sub_page format for subpages 01 h - FEh 


The ALLOCATION LENGTH field is defined in clause 2.1.4.5. 

An application client may request any one or all of the supported mode pages from the device server. If an 
application client issues a MODE SENSE command with a page code or subpage code value not implemented 
by the logical unit, the command shall be terminated with CHECK CONDITION status, with the sense key set 
to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 

If an application client requests all supported mode pages, the device server shall return the supported pages 
in ascending page code order beginning with mode page 01 h. If mode page OOh is implemented, the device 
server shall return mode page OOh after all other mode pages have been returned. 

If the PC field and the PAGE CODE field are both set to zero, the device server should return a mode parame¬ 
ter header and block descriptor, if applicable. 

The mode parameter list for all device types for MODE SELECT and MODE SENSE is defined in 3.13. Parts of 
the mode parameter list are specifically defined for each device type. Definitions for the parts of each mode 
parameter list that are unique for each device-type may be found in the applicable command standards. 

3.13.1.1 Current values 

A PC field value of 00b requests that the device server return the current values of the mode parameters. The 
current values returned are: 

a) The current values of the mode parameters established by the last successful MODE SELECT command; 

b) The saved values of the mode parameters if a MODE SELECT command has not successfully completed 
since the mode parameters were restored to their saved values (see 3.9); or 

c) The default values of the mode parameters if a MODE SELECT command has not successfully completed 
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since the mode parameters were restored to their default values (see 3.9). 


3.13.1.2 Changeable values 

A PC field value of 01 b requests that the device server return a mask denoting those mode parameters that are 
changeable. In the mask, the bits in the fields of the mode parameters that are changeable all shall be set to 
one and the bits in the fields of the mode parameters that are non-changeable (i.e., defined by the logical unit) 
all shall be set to zero. 

If the logical unit does not implement changeable parameters mode pages and the device server receives a 
MODE SENSE command with 01 b in the PC field, then the command shall be terminated with CHECK CONDI¬ 
TION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID 
FIELD IN CDB. 

An attempt to change a non-changeable mode parameter using the MODE SELECT command shall result in 
an error condition (see 3.9). 

The application client should issue a MODE SENSE command with the PC field set to 01b and the page code 
field set to 3Fh to determine which mode pages are supported, which mode parameters within the mode pages 
are changeable, and the supported length of each mode page prior to issuing any MODE SELECT commands. 

3.13.1.3 Default values 

A PC field value of 10b requests that the device server return the default values of the mode parameters. 
Unsupported parameters shall be set to zero. Default values should be accessible even if the logical unit is not 
ready. 


3.13.1.4 Saved values 

A PC field value of 11b requests that the device server return the saved values of the mode parameters. Mode 
parameters not supported by the logical unit shall be set to zero. If saved values are not implemented, the 
command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, 
and the additional sense code set to SAVING PARAMETERS NOT SUPPORTED. 

The method of saving parameters is vendor specific. The parameters are preserved in such a manner that they 
are retained when the device is powered down. All saveable mode pages should be considered saved when a 
MODE SELECT command issued with the SP bit set to one has returned a GOOD status or after the success¬ 
ful completion of a FORMAT UNIT command. 

3.13.1.5 Initial responses 

After a logical unit reset, the device server shall respond in the following manner: 
a) If default values are requested, report the default values; 

(b) If saved values are requested, report valid restored mode parameters, or restore the mode parameters 
and report them. If the saved values of the mode parameters are not able to be accessed from the 
nonvolatile vendor specific location, the command shall be terminated with CHECK CONDITION sta¬ 
tus, with the sense key set to NOT READY. If saved parameters are not implemented, respond as 
defined in 3.13.1.4; or 

(c) If current values are requested and the current values have been sent by the application client via a 
MODE SELECT command, the current values shall be returned. If the current values have not been 
sent, the device server shall return: 

a) The saved values, if saving is implemented and saved values are available; or 

b) The default values. 
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3.14 


MODE SENSE(IO) command 


The MODE SENSE(IO) command (see table 64) provides a means for a device server to report parameters to 
an application client. It is a complementary command to the MODE SELECT(IO) command. Device servers 
that implement the MODE SENSE(IO) command shall also implement the MODE SELECT(IO) command. 

Table 64 — MODE SENSE(IO) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (5Ah) 

1 

Reserved LLBAA DBD Reserved 

2 

PC PAGE CODE 

3 

SUBPAGE CODE 

4 

Reserved 

6 


7 

(MSB) ALLOCATION LENGTH 

8 

(LSB) 

9 

CONTROL 


LLBAA (Long LBA Accepted) bit 

1 If the Long LBA Accepted (LLBAA) bit is set to one, the device server is allowed to return parameter data with the 
LONGLBA bit equal to one. 

0 If LLBAA bit is set to zero, the LONGLBA bit shall be zero in the parameter data returned by the device server. 

See the MODE SENSE(6) command (3.13) for a description of the other fields and operation of this command. 
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3.15 


PERSISTENT RESERVE IN command 


3.15.1 PERSISTENT RESERVE IN command introduction 

The PERSISTENT RESERVE IN command (see table 65) is used to obtain information about persistent reser¬ 
vations and reservation keys (i.e., registrations) that are active within a device server. This command is used in 
conjunction with the PERSISTENT RESERVE OUT command (see 3.16). 

Table 65 — PERSISTENT RESERVE IN command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (5Eh) 

1 

Reserved SERVICE ACTION 

2 

Reserved 

6 


7 

(MSB) ALLOCATION LENGTH 

8 

(LSB) 

9 

CONTROL 


The service action codes for the PERSISTENT RESERVE IN command are defined in table 66. 

Table 66 — PERSISTENT RESERVE IN service action codes 


Code 

Name 

Description 

Reference 

OOh 

READ KEYS 

Reads all registered reservation keys (i.e., registra¬ 
tions) as described in SPC-4 clause 5.6.5.2 

3.15.2 

01 h 

READ RESERVATION 

Reads the current persistent reservations as 
described in SPC-4 clause 5.6.5.3 

3.15.3 

02h 

REPORT CAPABILITIES 

Returns capability information 

3.15.4 

03h 

READ FULL STATUS 

Reads complete information about all registrations 
and the persistent reservations, if any 

3.15.5 

04h -1 Fh 

Reserved 

Reserved 



3.15.2 READ KEYS service action 

The READ KEYS service action requests that the device server return a parameter list containing a header and a list of 
each currently registered l_T nexus’ reservation key. If multiple l_T nexuses have registered with the same key, then that 
key value shall be listed multiple times, once for each such registration. 

For more information on READ KEYS see SPC-4. 

The format for the parameter data provided in response to a PERSISTENT RESERVE IN command with the 
READ KEYS service action is shown in table 67. 
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Table 67 — PERSISTENT RESERVE IN parameter data for READ KEYS 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

(MSB) PRGENERATION 

3 

(LSB) 

4 

(MSB) ADDITIONAL LENGTH (N-7) 

7 

(LSB) 


Reservation key list 

8 

(MSB) First reservation key 

15 

(LSB) 



n-7 

(MSB) Last reservation key 

n 

(LSB) 


PRGENERATION (Persistent Reservations Generation) field 

The Persistent Reservations Generation (PRGENERATION) field shall contain a 32-bit counter maintained by the device 
server that shall be incremented every time a PERSISTENT RESERVE OUT command requests a REGISTER service 
action, a REGISTER AND IGNORE EXISTING KEY service action, a REGISTER AND MOVE service action, a CLEAR 
service action, a PREEMPT service action, or a PREEMPT AND ABORT service action. The counter shall not be incre¬ 
mented by a PERSISTENT RESERVE IN command, by a PERSISTENT RESERVE OUT command that performs a 
RESERVE or RELEASE service action, or by a PERSISTENT RESERVE OUT command that is terminated due to an error 
or reservation conflict. Regardless of the APTPL bit value the PRGENERATION value shall be set to zero by a power on. 

ADDITIONAL LENGTH field 

The ADDITIONAL LENGTH field contains a count of the number of bytes in the Reservation key list. The relationship 
between the ADDITIONAL LENGTH field and the CDB ALLOCATION LENGTH field is defined in 2.1.4.5. 

The reservation key list contains the 8-byte reservation keys for all l_T nexuses that have been registered see SPC-4 5.6.6. 

3.15.3 READ RESERVATION service action 


3.15.3.1 READ RESERVATION service action introduction 

The READ RESERVATION service action requests that the device server return a parameter list containing a 
header and the persistent reservation, if any, that is present in the device server. 

For more information on READ RESERVATION see SPC-4. 


3.15.3.2 PERSISTENT RESERVE IN parameter data for READ RESERVATION 

When no persistent reservation is held, the format for the parameter data provided in response to a PERSIS¬ 
TENT RESERVE IN command with the READ RESERVATION service action is shown in table 68. 
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Table 68 — PERSISTENT RESERVE IN data for READ RESERVATION with no reservation held 


Bit 7 6 5 4 3 

Byte 


0 (MSB) PRGENERATION 


3 


4 (MSB) ADDITIONAL LENGTH 


2 10 


_(LSB^ 

( 0 ) _ 

(LSB) 


PRGENERATION field 

The PRGENERATION field shall be as defined for the PERSISTENT RESERVE IN command with READ KEYS service 
action parameter data (see 3.15.2). 

ADDITIONAL LENGTH field 

The ADDITIONAL LENGTH field shall be set to zero, indicating that no persistent reservation is held. 

When a persistent reservation is held, the format for the parameter data provided in response to a PERSIS¬ 
TENT RESERVE IN command with the READ RESERVATION service action is shown in table 69. 

Table 69 — PERSISTENT RESERVE IN parameter data for READ RESERVATION with reservation 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

(MSB) PRGENERATION 

3 

(LSB) 

4 

(MSB) ADDITIONAL LENGTH (1 Oh) 

7 

(LSB) 

8 

(MSB) RESERVATION KEY 

15 

(LSB) 

16 

Obsolete 

19 


20 

Reserved 

21 

SCOPE TYPE 

22 

Obsolete 

23 



PRGENERATION field 

The PRGENERATION field shall be as defined for the PERSISTENT RESERVE IN command with READ KEYS service 
action parameter data. 

ADDITIONAL LENGTH field 

The ADDITIONAL LENGTH field contains a count of the number of bytes to follow and shall be set to 16. The relationship 
between the ADDITIONAL LENGTH field and the CDB ALLOCATION LENGTH field is defined in 2.1.4.5. 
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RESERVATION KEY field 

The RESERVATION KEY field shall contain the reservation key under which the persistent reservation is held (see SPC-4). 

SCOPE field 

The SCOPE field shall be set to LU_SCOPE (see 3.15.3.3). 

TYPE field 

The type field shall contain the persistent reservation type (see 3.15.3.4) specified in the PERSISTENT RESERVE OUT 
command that created the persistent reservation. 

The obsolete fields in bytes 16 through 19, byte 22, and byte 23 were defined in a previous standard. 

3.15.3.3 Persistent reservations scope 

The scope field (see table 70) shall be set to LU_SCOPE, specifying that the persistent reservation applies to 
the entire logical unit. 

Table 70 — Persistent reservation scope codes 


Code 

Name 

Description 

Oh 

1h-2h 

3h - Fh 

LU_SCOPE 

Persistent reservation applies to the full logical unit 

Obsolete 

Reserved 


The LU_SCOPE scope shall be implemented by all device servers that implement PERSISTENT RESERVE 
OUT. 
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3.15.3.4 Persistent reservations type 


The TYPE field (see table 71) specifies the characteristics of the persistent reservation being established for all 
logical blocks within the logical unit. SPC-4 Table 31 defines the persistent reservation types under which each 
command defined in the standard is allowed to be processed. Each other command standard (e.g., SBC-2, 
SSC-2, SMC-2, MMC-4, or SES-2) defines the persistent reservation types under which each command 
defined in that command standard is allowed to be processed. 


Table 71 — Persistent reservation type codes 


Code 

Name 

Description 

Oh 


Obsolete 

1h 

Write 

Exclusive 

Access Restrictions: Some commands (e.g., media-access write commands) are only 
allowed for the persistent reservation holder (see SPC-4 clause 5.6.9). 

Persistent Reservation Holder: There is only one persistent reservation holder. 

2h 


Obsolete 

3h 

Exclusive 

Access 

Access Restrictions: Some commands (e.g., media-access commands) are only allowed 
for the persistent reservation holder (see SPC-4 clause 5.6.9). 

Persistent Reservation Holder: There is only one persistent reservation holder. 

4h 


Obsolete 

5h 

Write Exclu¬ 
sive - Regis¬ 
trants 

Only 

Access Restrictions: Some commands (e.g., media-access write commands) are only 
allowed for registered l_T nexuses. 

Persistent Reservation Holder: There is only one persistent reservation holder (see SPC- 
4 clause 5.6.9). 

6h 

Exclusive 
Access - 
Registrants 
Only 

Access Restrictions: Some commands (e.g., media-access commands) are only allowed 
for registered l_T nexuses. 

Persistent Reservation Holder: There is only one persistent reservation holder (see SPC- 
4 clause 5.6.9). 

7h 

Write Exclu¬ 
sive - All 

Registrants 

Access Restrictions: Some commands (e.g., media-access write commands) are only 
allowed for registered l_T nexuses. 

Persistent Reservation Holder: Each registered l_T nexus is a persistent reservation 
holder (see SPC-4 clause 5.6.9). 

8h 

Exclusive 
Access - All 

Registrants 

Access Restrictions: Some commands (e.g., media-access commands) are only allowed 
for registered l_T nexuses. 

Persistent Reservation Holder: Each registered l_T nexus is a persistent reservation 
holder (see SPC-4 clause 5.6.9). 

9h - Fh 

Reserved 


3.15.4 REPORT CAPABILITIES service action 

The REPORT CAPABILITIES service action requests that the device server return information on persistent 
reservation features. 

The format for the parameter data provided in response to a PERSISTENT RESERVE IN command with the 
REPORT CAPABILITIES service action is shown in table 72. 
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Table 72 — PERSISTENT RESERVE IN parameter data for REPORT CAPABILITIES 


Bit 

Byte 

7 6 5 4 3 2 1 

0 

0 

(MSB) LENGTH (0008h) 

7 

(LSB) 

8 

Reserved CRH SIP_C ATP_C Reserved 

PTPL_C 

9 

TMV Reserved 

PTPLA 

10 

PERSISTENT RESERVATION TYPE MASK 

11 


12 

Reserved 

13 



LENGTH field 

The LENGTH field indicates the length in bytes of the parameter data. The relationship between the LENGTH field and the 

CDB ALLOCATION LENGTH field is defined in clause 2.2.6 of this manual. 

CRH (Compatible Reservation Handling) field 

1 A Compatible Reservation Handling (CRH) bit set to one indicates that the device server supports the exceptions to 
the SPC-4 RESERVE and RELEASE commands described in (see SPC-4). 

0 A CRH bit set to zero indicates that RESERVE(6) command, RESERVE(IO) command, RELEASE(6) command, 
and RELEASE(IO) command are processed as defined in SPC-4. 

SIP_C (Specify Initiator Ports Capable) bit 

1 A Specify Initiator Ports Capable (SIP_C) bit set to one indicates that the device server supports the SPEC_I_PT bit 
in the PERSISTENT RESERVE OUT command parameter data (see 3.16.3). 

0 An SIP_C bit set to zero indicates that the device server does not support the SPEC_I_PT bit in the PERSISTENT 
RESERVE OUT command parameter data. 

ATP C (Target Ports Capable) bit 

1 An All Target Ports Capable (ATP_C) bit set to one indicates that the device server supports the ALL_TG_PT bit in 
the PERSISTENT RESERVE OUT command parameter data. 

0 An ATP C bit set to zero indicates that the device server does not support the ALL_TG_PT bit in the PERSISTENT 
RESERVE OUT command parameter data. 

PTPL_C (Persist Through Power Loss Capable) bit 

1 A Persist Through Power Loss Capable (PTPL_C) bit set to one indicates that the device server supports the persist 
through power loss capability see SPC-4 for persistent reservations and the APTPL bit in the PERSISTENT 
RESERVE OUT command parameter data. 

0 An PTPL C bit set to zero indicates that the device server does not support the persist through power loss capabil¬ 
ity. 

TMV (Type Mask Valid) bit 

1 A Type Mask Valid (TMV) bit set to one indicates that the PERSISTENT RESERVATION TYPE MASK field contains 
a bit map indicating which persistent reservation types are supported by the device server. 

0 A TMV bit set to zero indicates that the PERSISTENT RESERVATION TYPE mask field shall be ignored. 
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PTPL A (Persist Through Power Loss Activated) bit 

1 A Persist Through Power Loss Activated (PTPL_A) bit set to one indicates that the persist through power loss capa¬ 
bility is activated (see SPC-4). 

0 A PTPL A bit set to zero indicates that the persist through power loss capability is not activated. 

The PERSISTENT RESERVATION TYPE MASK field (see table 73) contains a bit map that indicates the per¬ 
sistent reservation types that are supported by the device server. 

Table 73 — Persistent Reservation Type Mask format 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

4 

WREXAR 

EX_AC_RO 

WREXRO 

Reserved 

EXAC 

Reserved 

WREX 

Reserved 

5 

Reserved 

EX_AC_AR 


WR EX AR (Write Exclusive - All Registrants) bit 

1 A Write Exclusive - All Registrants (WR_EX_AR) bit set to one indicates that the device server supports the Write 
Exclusive - All Registrants persistent reservation type. 

0 An WR_EX_AR bit set to zero indicates that the device server does not support the Write Exclusive - All Registrants 
persistent reservation type. 

EX AC RO (Exclusive Access - Registrants Only) bit 

1 An Exclusive Access - Registrants Only (EX_AC_RO) bit set to one indicates that the device server supports the 
Exclusive Access - Registrants Only persistent reservation type. 

0 An EX_AC_RO bit set to zero indicates that the device server does not support the Exclusive Access - Registrants 
Only persistent reservation type. 

WR EX RO (Write Exclusive - Registrants Only) bit 

1 A Write Exclusive - Registrants Only (WR_EX_RO) bit set to one indicates that the device server supports the Write 
Exclusive - Registrants Only persistent reservation type. 

0 An WREXRO bit set to zero indicates that the device server does not support the Write Exclusive - Registrants 
Only persistent reservation type. 

EX AC (Exclusive Access) bit 

1 An Exclusive Access (EX_AC) bit set to one indicates that the device server supports the Exclusive Access persis¬ 
tent reservation type. 

0 An EXAC bit set to zero indicates that the device server does not support the Exclusive Access persistent reserva¬ 
tion type. 

WREX (Write Exclusive) bit 

1 A Write Exclusive (WR EX) bit set to one indicates that the device server supports the Write Exclusive persistent 
reservation type. 

0 An WR EX bit set to zero indicates that the device server does not support the Write Exclusive persistent reserva¬ 
tion type. 

EX_AC_AR (Exclusive Access - All Registrants) 

1 An Exclusive Access - All Registrants (EX_AC_AR) bit set to one indicates that the device server supports the 
Exclusive Access - All Registrants persistent reservation type. 

0 An EX_AC_AR bit set to zero indicates that the device server does not support the Exclusive Access - All Regis¬ 
trants persistent reservation type. 
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3.15.5 READ FULL STATUS service action 

The READ FULL STATUS service action requests that the device server return a parameter list describing the 
registration and persistent reservation status of each currently registered l_T nexus for the logical unit. 

For more information on READ FULL STATUS see SPC-4. 

The format for the parameter data provided in response to a PERSISTENT RESERVE IN command with the 
READ FULL STATUS service action is shown in table 74. 

Table 74 — PERSISTENT RESERVE IN parameter data for READ FULL STATUS 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

(MSB) PRGENERATION 

3 

(LSB) 

4 

(MSB) ADDITIONAL LENGTH (N-7) 

7 

(LSB) 


Full STatus descriptors 

8 



first full status descriptor (see table 75) 




Last full status descriptor (see table 75) 

n 



PRGENERATION field 

The PRGENERATION field shall be as defined for the PERSISTENT RESERVE IN command with READ 
KEYS service action parameter data (see 3.15.2). 

ADDITIONAL LENGTH field 

The ADDITIONAL LENGTH field contains a count of the number of bytes to follow in the full status descriptors. 
The relationship between the ADDITIONAL LENGTH field and the CDB ALLOCATION LENGTH field is defined 
in 2.1.4.5. 
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The format of the full status descriptors is shown in table 75. Each full status descriptor describes one or more 
registered l_T nexuses. The device server shall return persistent reservations status information for every reg¬ 
istered l_T nexus. 

Table 75 — PERSISTENT RESERVE IN full status descriptor format 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

(MSB) RESERVATION KEY 

7 

(LSB) 

8 

Reserved 

11 


12 

Reserved ALL_TG_PT RJ-IOLDER 

13 

SCOPE TYPE 

14 

Reserved 

17 


18 

(MSB) RELATIVE TARGET PORT IDENTIFIER 

19 

(LSB) 

20 

(MSB) ADDITIONAL DESCRIPTOR LENGTH (N-23) 

23 

(LSB) 

24 

TRANSPORTID 

n 



RESERVATION KEY field 

The RESERVATION KEY field contains the reservation key. 

RJfOLDER (Reservation Holder) bit 

1 A Reservation Holder (R HOLDER) bit set to one indicates that all l_T nexuses described by this full status descrip¬ 
tor are registered and are persistent reservation holders. 

0 A RJ-IOLDER bit set to zero indicates that all l_T nexuses described by this full status descriptor are registered but 
are not persistent reservation holders. 

ALL_TG_PT (All Target Ports) bit 

0 An All Target Ports (ALL_TG_PT) bit set to zero indicates that this full status descriptor represents a single l_T 
nexus. 

1 An ALL_TG_PT bit set to one indicates that: 

(a) This full status descriptor represents all the l_T nexuses that are associated with both: 

a. The initiator port specified by the TRANSPORTID field; and 

b. Every target port in the SCSI target device; 

(b) All the l_T nexuses are registered with the same reservation key; and 

(c) All the l_T nexuses are either reservation holders or not reservation holders as indicated by the 
RJHOLDER bit. 
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The device server is not required to return an ALL_TG_PT bit set to one. Instead, it may return separate full 
status descriptors for each l_T nexus. 

If the RJHOLDER bit is set to one (i.e., if the l_T nexus described by this full status descriptor is a reservation 
holder), the scope field and the type field are as defined in the READ RESERVATION service action parame¬ 
ter data (see 3.15.3). If the RJHOLDER bit is set to zero, the contents of the scope field and the type field are 
not defined by the standard. 

If the ALL_TG_PT bit set to zero, the RELATIVE TARGET PORT IDENTIFIER field contains the relative port 
identifier (see SPC-4) of the target port that is part of the l_T nexus described by this full status descriptor. If the 
ALL_TG_PT bit is set to one, the contents of the RELATIVE TARGET PORT IDENTIFIER field are not defined 
by the standard. 

The ADDITIONAL DESCRIPTOR LENGTH field contains a count of the number of bytes that follow in the 
descriptor (i.e., the size of the TRANSPORTID). 

The TRANSPORTID field contains a TRANSPORTID (see SPC-4) identifying the initiator port that is part of the 
l_T nexus or l_T nexuses described by this full status descriptor. 
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3.16 


PERSISTENT RESERVE OUT command 


3.16.1 PERSISTENT RESERVE OUT command introduction 

The PERSISTENT RESERVE OUT command (see table 76) is used to request service actions that reserve a 
logical unit for the exclusive or shared use of a particular l_T nexus. The command uses other service actions 
to manage and remove such persistent reservations. 

I_T nexuses performing PERSISTENT RESERVE OUT service actions are identified by a registered reserva¬ 
tion key provided by the application client. An application client may use the PERSISTENT RESERVE IN com¬ 
mand to obtain the reservation key, if any, for the l_T nexus holding a persistent reservation and may use the 
PERSISTENT RESERVE OUT command to preempt that persistent reservation. 

Table 76 — PERSISTENT RESERVE OUT command 


Bit 

Byte 

0 

7 6 5 4 3 2 1 0 

OPERATION CODE (5Fh) 

1 

Reserved SERVICE ACTION 

2 

SCOPE TYPE 

5 

Reserved 

6 


7 

(MSB) PARAMETER LIST LENGTH 

0 

(LSB) 

1 

CONTROL 


If a PERSISTENT RESERVE OUT command is attempted, but there are insufficient device server resources to 
complete the operation, the command shall be terminated with CHECK CONDITION status, with the sense key 
set to ILLEGAL REQUEST, and the additional sense code set to INSUFFICIENT REGISTRATION 
RESOURCES. 

The PERSISTENT RESERVE OUT command contains fields that specify a persistent reservation service 
action, the intended scope of the persistent reservation, and the restrictions caused by the persistent reserva¬ 
tion. The TYPE and SCOPE fields are defined in 3.15.3.4 and 3.15.3.3. If a scope field specifies a scope that 
is not implemented, the command shall be terminated with CHECK CONDITION status, with the sense key set 
to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 

Fields contained in the PERSISTENT RESERVE OUT parameter list specify the information required to per¬ 
form a particular persistent reservation service action. 

PARAMETER LIST LENGTH field 

The PARAMETER LIST LENGTH field specifies the number of bytes of parameter data for the PERSISTENT RESERVE 
OUT command. 

The parameter list shall be 24 bytes in length and the PARAMETER LIST LENGTH field shall contain 24 (18h), if the follow¬ 
ing conditions are true: 

a) The SPEC_I_PT bit (see 3.16.3) is set to zero; and 

b) The service action is not REGISTER AND MOVE. 
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If the SPEC_I_PT bit is set to zero, the service action is not REGISTER AND MOVE, and the parameter list 
length is not 24, then the command shall be terminated with CHECK CONDITION status, with the sense key 
set to ILLEGAL REQUEST, and the additional sense code set to PARAMETER LIST LENGTH ERROR. 

If the parameter list length is larger than the device server is able to process, the command should be termi¬ 
nated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional 
sense code set to PARAMETER LIST LENGTH ERROR. 


3.16.2 PERSISTENT RESERVE OUT service actions 

When processing the PERSISTENT RESERVE OUT service actions, the device server shall increment the 
PRGENERATION value as specified in 3.15.2. 

The PERSISTENT RESERVE OUT command service actions are defined in table 77. 


Table 77 — PERSISTENT RESERVE OUT service action codes 


Code 

Name 

Description 

(listed references are to SPC-4 clause 
numbers) 

PRGENERATIO 

N field 
incremented 
(see 3.15.2) 

Parameter 
list format 

OOh 

REGISTER 

Register a reservation key with the device 
server (see SPC-4 clause 5.6.6) or unregis¬ 
ter a reservation key (see SPC-4 clause 
5.6.10.3). 

Yes 

Basic 

(see 3.16.3) 

Olh 

RESERVE 

Creates a persistent reservation having a 
specified scope and type (see SPC-4 clause 
5.6.8). The scope and type of a persistent 
reservation are defined in 3.15.3.3 and 
3.15.3.4. 

No 

Basic 

(see 3.16.3) 

02h 

RELEASE 

Releases the selected persistent reservation 
(see SPC-4 clause 5.6.10.2). 

No 

Basic 

(see 3.16.3) 

03h 

CLEAR 

Clears all reservation keys (i.e., registra¬ 
tions) and all persistent reservations (see 
SPC-4 clause 5.6.10.6). 

Yes 

Basic 

(see 3.16.3) 

04h 

PREEMPT 

Preempts persistent reservations and/or 
removes registrations (see SPC-4 clause 
5.6.10.4). 

Yes 

Basic 

(see 3.16.3) 

05h 

PREEMPT AND 
ABORT 

Preempts persistent reservations and/or 
removes registrations and aborts all tasks for 
all preempted l_T nexuses (see SPC-4 
clause 5.6.10.5 and 5.6.10.5) 

Yes 

Basic 

(see 3.16.3) 

06h 

REGISTER AND 
IGNORE EXIST¬ 
ING KEY 

Register a reservation key with the device 
server (see SPC-4 clause 5.6.6) or unregis¬ 
ter a reservation key (see SPC-4 clause 
5.6.10.3). 

Yes 

Basic 

(see 3.16.3) 

07h 

REGISTER AND 
MOVE 

Register a reservation key for another I T 
nexus with the device server and move a 
persistent reservation to that l_T nexus (see 
SPC-4 clause 5.6.7) 

Yes 

Register and 
move 

(see 3.16.4) 

08h - IFh 

Reserved 
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3.16.3 


Basic PERSISTENT RESERVE OUT parameter list 


The parameter list format shown in table 78 shall be used by the PERSISTENT RESERVE OUT command 
with any service action except the REGISTER AND MOVE service action. All fields shall be sent, even if the 
field is not required for the specified service action and scope values. 

Table 78 — PERSISTENT RESERVE OUT parameter list 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

(MSB) RESERVATION KEY 

7 

(LSB) 

8 

(MSB) SERVICE ACTION RESERVATION KEY 

15 

(LSB) 

16 

Obsolete 

19 


20 

Reserved SPEC_I_PT ALL_TG_PT Reserved APTPL 

21 

Reserved 

22 

Obsolete 

23 


24 

ADDITIONAL PARAMETER DATA 

n 



The obsolete fields in bytes 16 through 19, byte 22 and byte 23 were defined in a previous standard. 

RESERVATION KEY field 

The RESERVATION KEY field contains an 8-byte value provided by the application client to the device server to identify 
the I T nexus that is the source of the PERSISTENT RESERVE OUT command. The device server shall verify that the 
contents of the RESERVATION KEY field in a PERSISTENT RESERVE OUT command parameter data matches the reg¬ 
istered reservation key for the l_T nexus from which the command was received, except for: 

a) The REGISTER AND IGNORE EXISTING KEY service action where the RESERVATION KEY field shall be 
ignored; and 

b) The REGISTER service action for an unregistered l_T nexus where the RESERVATION KEY field shall con¬ 
tain zero. 

Except as noted above, when a PERSISTENT RESERVE OUT command specifies a reservation key field 
other than the reservation key registered for the l_T nexus the device server shall return a RESERVATION 
CONFLICT status. Except as noted above, the reservation key of the l_T nexus shall be verified to be correct 
regardless of the service action and scope field values. 

SERVICE ACTION RESERVATION KEY field 

The SERVICE ACTION RESERVATION KEY field contains information needed for the following service actions: REGIS¬ 
TER, REGISTER AND IGNORE EXISTING KEY, PREEMPT, and PREEMPT AND ABORT. The SERVICE ACTION RESERVA¬ 
TION key field is ignored for the following service actions: RESERVE, RELEASE, and CLEAR. 

For the REGISTER service action and REGISTER AND IGNORE EXISTING KEY service action, the SERVICE ACTION 
RESERVATION KEY field contains: 

a) The new reservation key to be registered in place of the registered reservation key specified in the RESERVA- 
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TION KEY field; or 

b) Zero to unregister the registered reservation key specified in the RESERVATION KEY field. 

For the PREEMPT service action and PREEMPT AND ABORT service action, the service action reservation key field 
contains the reservation key of: 

a) The registrations to be removed; and 

b) If the SERVICE ACTION RESERVATION key field identifies a persistent reservation holder (see SPC-4), per¬ 
sistent reservations that are to be preempted. 

SPECJ_PT (Specify Initiator Ports) bit 

0 If the Specify Initiator Ports (SPECJ_PT) bit is set to zero, the device server shall apply the registration only to the 
I T nexus that sent the PERSISTENT RESERVE OUT command. 

1 If the SPECJ_PT bit is set to one for the REGISTER service action or the REGISTER AND IGNORE EXISTING 
KEY service action, then the additional parameter data shall include a list of transport IDs (see table 79) and the 
device server shall also apply the registration to the l_T nexus for each initiator port specified by a TRANSPORTID. 
If a registration fails for any initiator port (e.g., if the logical unit does not have enough resources available to hold 
the registration information), none of the other registrations shall be made. 


Table 79 — PERSISTENT RESERVE OUT specify initiator ports additional parameter data 


Bit 

Byte 

7 6 5 4 3 2 1 0 

24 

TRANSPORTID PARAMETER DATA LENGTH (N - 27) 

27 



TRANSPORTIDS LIST 

28 

FIRST TRANSPORTID 






LAST TRANSPORTID 

n 



RANSPORTID PARAMETER DATA LENGTH field 

The TRANSPORTID PARAMETER DATA LENGTH field specifies the number of bytes of TRANSPORTIDs that follow. 

The command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST: 

(a) If the value in the parameter list length field in the CDB does not include all of the additional parameter 
list bytes specified by the TRANSPORTID PARAMETER DATA LENGTH field; or 

(b) If the value in the TRANSPORTID PARAMETER DATA LENGTH field results in the truncation of a 
TRANSPORTID. 

The format of a TRANSPORTID is specified in SPC-4. 

ALL_TG_PT (All Target Ports) bit 

The All Target Ports (ALL_TG_PT) bit is valid only for the REGISTER service action and the REGISTER AND IGNORE 

EXISTING KEY service action, and shall be ignored for all other service actions. Support for the ALL_TG_PT bit is optional. 

1 If the device server receives a REGISTER service action or a REGISTER AND IGNORE EXISTING KEY service 
action with the ALL_TG_PT bit set to one, it shall create the specified registration on all target ports in the SCSI tar¬ 
get device known to the device server (i.e., as if the same registration request had been received individually 
through each target port). 
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0 If the device server receives a REGISTER service action or a REGISTER AND IGNORE EXISTING KEY service 
action with the ALL_TG_PT bit set to zero, it shall apply the registration only to the target port through which the 
PERSISTENT RESERVE OUT command was received. 

APTPL (Activate Persist Through Power Loss) bit 

The Activate Persist Through Power Loss (APTPL) bit is valid only for the REGISTER service action and the 
REGISTER AND IGNORE EXISTING KEY service action, and shall be ignored for all other service actions. 
Support for an APTPL bit equal to one is optional. If a device server that does not support an APTPL bit set to 
one receives that value in a REGISTER service action or a REGISTER AND IGNORE EXISTING KEY service 
action, the command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL 
REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 

If the last valid APTPL bit value received by the device server is zero, the loss of power in the SCSI target 
device shall release the persistent reservation for the logical unit and remove all registered reservation keys 
(see SPC-4). If the last valid APTPL bit value received by the device server is one, the logical unit shall retain 
any persistent reservation(s) that may be present and all reservation keys (i.e., registrations) for all l_T nex¬ 
uses even if power is lost and later returned (see SPC-4). 

Table 80 summarizes which fields are set by the application client and interpreted by the device server for each 
service action and scope value. 


Table 80 — PERSISTENT RESERVE OUT service actions and valid parameters (part 1 of 2) 


Service action 

Allowed SCOPE 

Parameters (part 1 of 2) 

TYPE 

RESERVATION 

KEY 

SERVICE 

ACTION 

RESERVATION 

KEY 

APTPL 

REGISTER 

ignored 

ignored 

valid 

valid 

valid 

REGISTER AND 
IGNORE 

EXISTING KEY 

ignored 

ignored 

ignored 

valid 

valid 

RESERVE 

LU_SCOPE 

valid 

valid 

ignored 

ignored 

RELEASE 

LU_SCOPE 

valid 

valid 

ignored 

ignored 

CLEAR 

ignored 

ignored 

valid 

ignored 

ignored 

PREEMPT 

LU_SCOPE 

valid 

valid 

valid 

ignored 

PREEMPT AND 
ABORT 

LU_SCOPE 

valid 

valid 

valid 

ignored 

REGISTER AND 
MOVE 

LU_SCOPE 

valid 

valid 

valid 

not 

applicable a 


a The parameter list format for the REGISTER AND MOVE service action is described in 3.16.4. 


SCSI Commands Reference Manual, Rev. A 


107 




Table 81 — PERSISTENT RESERVE OUT service actions and valid parameters (part 2 of 2) 


Service action 

Allowed SCOPE 

Parameters (part 2 of 2) 

ALL_TG_PT 

SPEC_I_PT 

REGISTER 

ignored 

valid 

valid 

REGISTER AND IGNORE 

EXISTING KEY 

ignored 

valid 

valid 

RESERVE 

LU_SCOPE 

ignored 

ignored 

RELEASE 

LU_SCOPE 

ignored 

ignored 

CLEAR 

ignored 

ignored 

ignored 

PREEMPT 

LU_SCOPE 

ignored 

ignored 

PREEMPT AND ABORT 

LU_SCOPE 

ignored 

ignored 

REGISTER AND MOVE 

LU_SCOPE 

not 

applicable a 

not 

applicable a 


a The parameter list format for the REGISTER AND MOVE service action is described in 3.16.4. 


3.16.4 PERSISTENT RESERVE OUT command with REGISTER AND MOVE service 

The parameter list format shown in table 82 shall be used by the PERSISTENT RESERVE OUT command 
with REGISTER AND MOVE service action. 

Table 82 — PERSISTENT RESERVE OUT command with REGISTER AND MOVE service 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

(MSB) RESERVATION KEY 

7 

(LSB) 

8 

(MSB) SERVICE ACTION RESERVATION KEY 

15 

(LSB) 

16 

Reserved 

17 

Reserved UNREG APTPL 

18 

(MSB) RELATIVE TARGET PORT IDENTIFIER 

19 

(LSB) 

20 

(MSB) TRANSPORTID PARAMETER DATA LENGTH (N - 23) 

23 

(LSB) 

24 

TRANSPORTID 

n 
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RESERVATION KEY field 


The RESERVATION KEY field contains an 8-byte value provided by the application client to the device server to identify the 
l_T nexus that is the source of the PERSISTENT RESERVE OUT command. The device server shall verify that the con¬ 
tents of the RESERVATION KEY field in a PERSISTENT RESERVE OUT command parameter data matches the regis¬ 
tered reservation key for the l_T nexus from which the command was received. If a PERSISTENT RESERVE OUT 
command specifies a reservation key field other than the reservation key registered for the l_T nexus, the device server 
shall return a RESERVATION CONFLICT status. 

SERVICE ACTION RESERVATION KEY field 

The SERVICE ACTION RESERVATION KEY field contains the reservation key to be registered to the speci¬ 
fied l_T nexus. 

APTPL (Activate Persist Through Power Loss) bit 

The Activate Persist Through Power Loss (APTPL) bit set to one is optional. If a device server that does not support an 
APTPL bit set to one receives that value, it shall return CHECK CONDITION status, with the sense key set to ILLEGAL 
REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 

If the last valid APTPL bit value received by the device server is zero, the loss of power in the SCSI target 
device shall release the persistent reservation for the logical unit and remove all registered reservation keys 
(see 5.6.5). If the last valid APTPL bit value received by the device server is one, the logical unit shall retain 
any persistent reservation(s) that may be present and all reservation keys (i.e., registrations) for all l_T nex¬ 
uses even if power is lost and later returned (see SPC-4). 

UNREG (Unregister) bit 

0 The unregister (UNREG) bit set to zero specifies that the device server shall not unregister the l_T nexus on which 
the PERSISTENT RESERVE OUT command REGISTER AND MOVE service action was received. 

1 An UNREG bit set to one specifies that the device server shall unregister the l_T nexus on which the PERSISTENT 
RESERVE OUT command REGISTER AND MOVE service action was received. 

RELATIVE TARGET PORT IDENTIFIER field 

The RELATIVE TARGET PORT IDENTIFIER field specifies the relative port identifier of the target port in the 
I T nexus to which the persistent reservation is to be moved. 

TRANSPORTID DESCRIPTOR LENGTH field 

The TRANSPORTID DESCRIPTOR LENGTH field specifies the number of bytes of the TRANSPORTID that 
follows, shall be a minimum of 24 bytes, and shall be a multiple of 4. 

TRANSPORTID field 

The TRANSPORTID specifies the initiator port in the I T nexus to which the persistent reservation is to be 
moved. The format of the TRANSPORTID is defined in SPC-4. 

The command shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL 
REQUEST: 

a) If the value in the parameter list length field in the CDB does not include all of the parameter list bytes specified 
by the TRANSPORTID PARAMETER DATA LENGTH field; or 

b) If the value in the TRANSPORTID PARAMETER DATA LENGTH field results in the truncation of a TRANS¬ 
PORTID. 
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3.17 PRE-FETCH (10) command, PRE-FETCH (16) command 

These commands are not supported by Seagate disc drives. The command shall be terminated with CHECK 
CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to 
INVALID COMMAND OPERATION CODE. 


3.18 PREVENT ALLOW MEDIUM REMOVAL command 

This command is not supported by Seagate Disc drives. The drive returns CHECK CONDITION status with 
ILLEGAL REQUEST in the Sens Key. 

The PREVENT ALLOW MEDIUM REMOVAL command (see SPC-4 table 118) requests that the logical unit 
enable or disable the removal of the medium. The logical unit shall not allow medium removal if any initiator 
port currently has medium removal prevented. 
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3.19 


READ (6) command 


The READ (6) command (see table 83) requests that the device server read the specified logical block(s) and 
transfer them to the data-in buffer. Each logical block read includes user data and, if the medium is formatted 
with protection information enabled, protection information. Each logical block transferred includes user data 
but does not include protection information. The most recent data value written, or to be written if cached, in 
the addressed logical blocks shall be returned. 


Table 83 — READ (6) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (08h) 

1 

Reserved (MSB) 

2 

LOGICAL BLOCK ADDRESS 

3 

(LSB) 

4 

TRANSFER LENGTH 

5 

CONTROL 


The cache control bits are not provided for this command. Direct-access block devices with cache may have values for the 
cache control bits that affect the READ (6) command; however, no default values are defined by the standard. If explicit 
control is required, the READ (10) command should be used. 

LOGICAL BLOCK ADDRESS field 

The LOGICAL BLOCK ADDRESS field specifies the first logical block accessed by this command. If the logical block 
address exceeds the capacity of the medium the device server shall terminate the command with CHECK CONDITION sta¬ 
tus with the sense key set to ILLEGAL REQUEST and the additional sense code set to LOGICAL BLOCK ADDRESS OUT 
OF RANGE. 

TRANSFER LENGTH field 

The TRANSFER LENGTH field specifies the number of contiguous logical blocks of data that shall be read and transferred 
to the data-in buffer, starting with the logical block specified by the LOGICAL BLOCK ADDRESS field. A TRANSFER 
LENGTH field set to zero specifies that 256 logical blocks shall be read. Any other value specifies the number of logical 
blocks that shall be read. If the logical block address plus the transfer length exceeds the capacity of the medium, the 
device server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST 
and the additional sense code set to LOGICAL BLOCK ADDRESS OUT OF RANGE. The TRANSFER LENGTH field is 
constrained by the MAXIMUM TRANSFER LENGTH field in the Block Limits VPD page. 

a) For the READ (10) command, READ (12) command, READ (16) command, and READ (32) command, a 
TRANSFER LENGTH field set to zero specifies that no logical blocks are read. 

b) Although the READ (6) command is limited to addressing logical blocks up to a capacity of 2 Gigabytes, for 
block lengths of 512 bytes, this command has been maintained as mandatory since some system initialization rou¬ 
tines require that the READ (6) command be used. System initialization routines should migrate from the READ 
(6) command to the READ (10) command, which is capable of addressing 2 Terabytes with block lengths of 512 
bytes, or the READ (16) command to address more than 2 Terabytes. 
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The device server shall check the protection information read from the medium before returning status for the 
command as described in table 84. 


Table 84 — Protection information checking for READ (6) 


Logical unit 
formatted with 
protection 
information 

Shall device 
server transmit 
protection 
information? 

Field in 
protection 
information f 

Extended 
INQUIRY Data 
VPD page bit 
value d 

If check fails b c , additional sense 
code 

Yes 

No 

LOGICAL BLOCK 
GUARD 

GRDCHK=1 

LOGICAL BLOCK GUARD CHECK 
FAILED 

GRDCHK = 0 

No check performed 

LOGICAL BLOCK 
APPLICATION 
TAG 

APPCHK = 1 a 

LOGICAL BLOCK APPLICATION 

TAG CHECK FAILED 

APPCHK = 0 

No check performed 

LOGICAL BLOCK 
REFERENCE 
TAG 

REFCHK = 1 9 

LOGICAL BLOCK REFERENCE TAG 
CHECK FAILED 

REFCHK = 0 

No check performed 

No 

No protection information available to check 


a The device server checks the logical block application tag only if it has knowledge of the contents of the 
LOGICAL BLOCK APPLICATION TAG field. The method for acquiring this knowledge is not defined by 
this standard. 

b If an error is reported, the sense key shall be set to ABORTED COMMAND. 
c If multiple errors occur, the selection of which error to report is not defined by this standard. 
d See the Extended INQUIRY Data VPD page (see SPC-4) for the definitions of the GRDCHK bit, 
APPCHK bit, and REFCHK bit. 
e If the device server detects a: 

a) LOGICAL BLOCK APPLICATION TAG field set to FFFFh and type 1 protection (See SBC-4) or type 
2 protection (See SBC-4) is enabled; or 

b) LOGICAL BLOCK APPLICATION TAG field set to FFFFh, LOGICAL BLOCK REFERENCE TAG 
field set to FFFF FFFFh, and type 3 protection (See SBC-4) is enabled, 

then the device server shall not check any protection information in the associated logical block. 

If type 1 protection is enabled, the device server checks the logical block reference tag by comparing it to 
the lower 4 bytes of the LBA associated with the logical block. If type 2 protection or type 3 protection is 
enabled, the device server checks the logical block reference tag only if it has knowledge of the contents 
of the LOGICAL BLOCK REFERENCE TAG field. The method for acquiring this knowledge is not 
defined by this standard. 
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3.20 


READ (10) command 


The READ (10) command (see table 85) requests that the device server read the specified logical block(s) and 
transfer them to the data-in buffer. Each logical block read includes user data and, if the medium is formatted 
with protection information enabled, protection information. Each logical block transferred includes user data 
and may include protection information, based on the RDPROTECT field and the medium format. The most 
recent data value written in the addressed logical block shall be returned. 


Table 85 — READ (10) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (28h) 

1 

RDPROTECT DPO FUA Reserved FUA_NV Obsolete 

2 

(MSB) LOGICAL BLOCK ADDRESS 

5 

(LSB) 

6 

Reserved GROUP NUMBER 

7 

(MSB) TRANSFER LENGTH 

8 

(LSB) 

9 

CONTROL 


RDPROTECT field 

The device server shall check the protection information read from the medium before returning status for the command 
based on the RDPROTECT field as described in table 86. 


Table 86 — RDPROTECT field (Sheet 1 of 4) 


Code 

Logical unit 
formatted with 
protection 
information 

Shall device 

server 

transmit 

protection 

information? 

Field in 
protection 
information ■ 

Extended 

INQUIRY Data 

VPD page bit 
value 9 

If check fails d f , additional 
sense code 

000b 

Yes 

No 

LOGICAL 
BLOCK GUARD 

GRD_CHK= 1 

LOGICAL BLOCK GUARD 
CHECK FAILED 

GRDCHK = 0 

NO CHECK PERFORMED 

LOGICAL 
BLOCK APPLI¬ 
CATION TAG 

APP_CHK = 1 c 

LOGICAL BLOCK APPLICA¬ 
TION TAG CHECK FAILED 

APP_CHK = 0 

NO CHECK PERFORMED 

LOGICAL 
BLOCK REFER¬ 
ENCE TAG 

REFCHK= 1 k 

LOGICAL BLOCK REFER¬ 
ENCE TAG CHECK FAILED 

REFCHK = 0 

NO CHECK PERFORMED 

No 

No protection information available to check 
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Table 86 — RDPROTECT field (Sheet 2 of 4) 


Code 

Logical unit 
formatted with 
protection 
information 

Shall device 

server 

transmit 

protection 

information? 

Field in 
protection 
information ■ 

Extended 

INQUIRY Data 

VPD page bit 
value 9 

If check fails d f >, additional 
sense code 




LOGICAL 
BLOCK GUARD 

GRD_CHK= 1 

LOGICAL BLOCK GUARD 
CHECK FAILED 





GRD_CHK = 0 

NO CHECK PERFORMED 

001b 

Yes 

Yes e 

LOGICAL 
BLOCK APPLI¬ 
CATION TAG 

APP_CHK = 1 c 

LOGICAL BLOCK APPLICA¬ 
TION TAG CHECK FAILED 

101b b 



APPCHK = 0 

NO CHECK PERFORMED 




LOGICAL 
BLOCK REFER¬ 
ENCE TAG 1 

REF_CHK = 1 k 

LOGICAL BLOCK REFER¬ 
ENCE TAG CHECK FAILED 




REF_CHK = 0 

NO CHECK PERFORMED 


No a 

No protection information available to transmit to the data-in buffer or for checking 




LOGICAL 
BLOCK GUARD 

NO CHECK PERFORMED 




LOGICAL 
BLOCK APPLI¬ 
CATION TAG 

APP_CHK = 1 c 

LOGICAL BLOCK APPLICA¬ 
TION TAG CHECK FAILED 

010b b 

Yes 

Yes e 

APP_CHK = 0 

NO CHECK PERFORMED 




LOGICAL 
BLOCK REFER¬ 
ENCE TAG 1 

REFCHK= 1 k 

LOGICAL BLOCK REFER¬ 
ENCE TAG CHECK FAILED 




REFCHK = 0 

NO CHECK PERFORMED 


No a 

No protection information available to transmit to the data-in buffer or for checking 




LOGICAL 
BLOCK GUARD 

NO CHECK PERFORMED 

011b b 

Yes 

Yes e 

LOGICAL 
BLOCK APPLI¬ 
CATION TAG 

NO CHECK PERFORMED 




LOGICAL 
BLOCK REFER¬ 
ENCE TAG 1 

NO CHECK PERFORMED 


No a 

No protection information available to transmit to the data-in buffer or for checking 
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Table 86 — RDPROTECT field (Sheet 3 of 4) 


Code 

Logical unit 
formatted with 
protection 
information 

Shall device 

server 

transmit 

protection 

information? 

Field in 
protection 
information ■ 

Extended 

INQUIRY Data 

VPD page bit 
value 9 

If check fails d f -, additional 
sense code 

100b b 

Yes 

Yes e 

LOGICAL 
BLOCK GUARD 

GRDCHK= 1 

LOGICAL BLOCK GUARD 
CHECK FAILED 

GRD_CHK = 0 

NO CHECK PERFORMED 

LOGICAL 
BLOCK APPLI¬ 
CATION TAG 

NO CHECK PERFORMED 

LOGICAL 
BLOCK REFER¬ 
ENCE TAG 1 

NO CHECK PERFORMED 

No a 

No protection information available to transmit to the data-in buffer or for checking 

101b- 

111b 

Reserved 
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Table 86 — RDPROTECT field (Sheet 4 of 4) 


Code 

Logical unit 
formatted with 
protection 
information 

Shall device 

server 

transmit 

protection 

information? 

Field in 
protection 
information ■ 

Extended 

INQUIRY Data 

VPD page bit 
value 9 

If check fails d f , additional 
sense code 


a A read operation to a logical unit that supports protection information and has not been formatted with 
protection information shall be terminated with CHECK CONDITION status with the sense key set to 
ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 
b If the logical unit does not support protection information the requested command should be terminated 
with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense 
code set to INVALID FIELD IN CDB. 

c The device server shall check the logical block application tag if it has knowledge of the contents of the 
LOGICAL BLOCK APPLICATION TAG field. If the READ (32) command (see 3.23) is used and the ATO 
bit is set to one in the Control mode page (see SPC-4), this knowledge is acquired from the EXPECTED 
LOGICAL BLOCK APPLICATION TAG field and the LOGICAL BLOCK APPLICATION TAG MASK field 
in the CDB. Otherwise, this knowledge may be acquired by a method not defined by the standard. 
d If an error is reported, the sense key shall be set to ABORTED COMMAND. 
e Transmit protection information to the data-in buffer. 

f If multiple errors occur, the selection of which error to report is not defined by the standard. 

9 See the Extended INQUIRY Data VPD page (see SPC-4) for the definitions of the GRD CHK bit, the 
APP CHK bit, and the REF CHK bit. 
h If the device server detects a: 

a) LOGICAL BLOCK APPLICATION TAG field set to FFFFh and type 1 protection (See SBC-4) or type 
2 protection (See SBC-4) is enabled; or 

b) LOGICAL BLOCK APPLICATION TAG field set to FFFFh, LOGICAL BLOCK REFERENCE TAG 
field set to FFFF FFFFh, and type 3 protection (See SBC-4) is enabled, 

then the device server shall not check any protection information in the associated logical block, 
i If the RTO_EN bit is set to zero in the READ CAPACITY (16) parameter data (see 3.27), the device server may 
process the command. If the RTO_EN bit is set to one, READ (10) commands, READ (12) commands, and READ 
(16) commands with the RDPROTECT field set to 000b may be processed by the device server. If the RTO_EN bit is 
set to one, the device server shall terminate READ (10) commands, READ (12) commands, and READ (16) 
commands with the RDPROTECT field not set to 000b with CHECK CONDITION status with the sense key set to 
ILLEGAL REQUEST and the additional sense code set to INVALID COMMAND OPERATION CODE, 
j If type 1 protection is enabled, the device server checks the logical block reference tag by comparing it to the 
lower 4 bytes of the LBA associated with the logical block. 

k If type 2 protection or type 3 protection is enabled, the device server checks the logical block reference 
tag if it has knowledge of the contents of the logical block reference tag field. If type 2 protection is 
enabled, then this knowledge may be acquired through the expected initial logical block reference tag 
field in a READ (32) command (see 3.23). If type 3 protection is enabled, then the method for acquiring 
this knowledge is not defined by this standard. 


DPO (Disable Page Out) bit 

0 A Disable Page Out (DPO) bit set to zero specifies that the retention priority shall be determined by the RETEN¬ 
TION PRIORITY fields in the Caching mode page (see 4.3.8). 

1 A DPO bit set to one specifies that the device server shall assign the logical blocks accessed by this command the 
lowest retention priority for being fetched into or retained by the cache. A DPO bit set to one overrides any retention 
priority specified in the Caching mode page. All other aspects of the algorithm implementing the cache replacement 
strategy are not defined by the standard. 

Note. The DPO bit is used to control replacement of logical blocks in the cache when the application cli¬ 
ent has information on the future usage of the logical blocks. If the DPO bit is set to one, the appli¬ 
cation client is specifying that the logical blocks accessed by the command are not likely to be 
accessed again in the near future and should not be put in the cache nor retained by the cache. If 
the DPO bit is set to zero, the application client is specifying that the logical blocks accessed by this 
command are likely to be accessed again in the near future. 
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The force unit access (FUA) and force unit access non-volatile cache (FUA_NV) bits are defined in table 87. 


Table 87 — Force unit access for read operations 


FUA 

FUA_NV 

Description 

0 

0 

The device server may read the logical blocks from volatile cache, non-volatile 
cache, and/or the medium. 

0 

1 

If the NVSUP bit is set to one in the Extended INQUIRY Data VPD page (see SPC-4), the 
device server shall read the logical blocks from non-volatile cache or the medium. If a non¬ 
volatile cache is present and a volatile cache contains a more recent version of a logical 
block, the device server shall write the logical block to: 

(a) non-volatile cache; and/or 

(b) the medium, 
before reading it. 

If the NV SUP bit is set to zero in the Extended INQUIRY Data VPD page (see SPC-4), the 
device server may read the logical blocks from volatile cache, non-volatile cache, and/or the 
medium. 

1 

0 or 1 

The device server shall read the logical blocks from the medium. If a cache contains a more 
recent version of a logical block, the device server shall write the logical block to the medium 
before reading it. 


LOGICAL BLOCK ADDRESS field 

The LOGICAL BLOCK ADDRESS field specifies the first logical block accessed by this command. If the logical block 
address exceeds the capacity of the medium the device server shall terminate the command with CHECK CONDITION sta¬ 
tus with the sense key set to ILLEGAL REQUEST and the additional sense code set to LOGICAL BLOCK ADDRESS OUT 
OF RANGE. 

GROUP NUMBER field 

The GROUP NUMBER field specifies the group into which attributes associated with the command should be collected. A 
GROUP NUMBER field set to zero specifies that any attributes associated with the command shall not be collected into any 
group. 

TRANSFER LENGTH field 

The TRANSFER LENGTH field specifies the number of contiguous logical blocks of data that shall be read and transferred 
to the data-in buffer, starting with the logical block specified by the LOGICAL BLOCK ADDRESS field. A TRANSFER 
LENGTH field set to zero specifies that no logical blocks shall be read. This condition shall not be considered an error. Any 
other value specifies the number of logical blocks that shall be read. If the logical block address plus the transfer length 
exceeds the capacity of the medium, the device server shall terminate the command with CHECK CONDITION status with 
the sense key set to ILLEGAL REQUEST and the additional sense code set to LOGICAL BLOCK ADDRESS OUT OF 
RANGE. The TRANSFER LENGTH field is constrained by the MAXIMUM TRANSFER LENGTH field in the Block Limits 
VPD page. 

For the READ (6) command, a TRANSFER LENGTH field set to zero specifies that 256 logical blocks are read. 
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3.21 


READ (12) command 


The READ (12) command (see table 88) requests that the device server read the specified logical block(s) and 
transfer them to the data-in buffer. Each logical block read includes user data and, if the medium is formatted 
with protection information enabled, protection information. Each logical block transferred includes user data 
and may include protection information, based on the RDPROTECT field and the medium format. 


Table 88 — READ (12) command 


Bit 

Byte 

7 

6 5 

4 3 2 1 0 

0 

OPERATION CODE (A8h) 

1 

RDPROTECT DPO FUA Reserved FUAJMV Obsolete 

2 

(MSB) 


LOGICAL BLOCK ADDRESS 

5 


(LSB) 

6 

(MSB) 


TRANSFER LENGTH 

9 


(LSB) 

10 

RESTRICTED 
FOR MMC-4 

Reserved 

GROUP NUMBER 

11 

CONTROL 


See the READ (10) command for the definitions of the fields in this command. 
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3.22 


READ (16) command 


The READ (16) command (see table 89) requests that the device server read the specified logical block(s) and 
transfer them to the data-in buffer. Each logical block read includes user data and, if the medium is formatted 
with protection information enabled, protection information. Each logical block transferred includes user data 
and may include protection information, based on the RDPROTECT field and the medium format. 


Table 89 — READ (16) command 


Bit 

Byte 

7 

6 5 

4 3 2 1 0 

0 

OPERATION CODE (88h) 

1 

RDPROTECT DPO FUA Reserved FUA_NV Reserved 

2 

(MSB) 


LOGICAL BLOCK ADDRESS 

9 


(LSB) 

10 

(MSB) 


TRANSFER LENGTH 

13 


(LSB) 

14 

Restricted 
for MMC-4 

Reserved 

GROUP NUMBER 

15 

CONTROL 


See the READ (10) command for the definitions of the fields in this command. 
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3.23 


READ (32) command 


The READ (32) command (see table 90) requests that the device server read the specified logical block(s) and 
transfer them to the data-in buffer. Each logical block read includes user data and, if the medium is formatted 
with protection information enabled, protection information. Each logical block transferred includes user data 
and may include protection information, based on the RDPROTECT field and the medium format. 

1. The READ (32) command shall only be processed if type 2 protection is enabled (see SBC-4). 


Table 90 — READ (32) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (7Fh) 

1 

CONTROL 

2 

Reserved 

5 


6 

Reserved GROUP NUMBER 

7 

ADDITIONAL CDB LENGTH (18h) 

8 

(MSB) SERVICE ACTION (0009h) 

9 

(LSB) 

10 

RDPROTECT DPO FUA Reserved FUA_NV Reserved 

11 

Reserved 

12 

(MSB) LOGICAL BLOCK ADDRESS 

19 

(LSB) 

20 

(MSB) EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG 

23 

(LSB) 

24 

(MSB) EXPECTED LOGICAL BLOCK APPLICATION TAG 

25 

(LSB) 

26 

(MSB) LOGICAL BLOCK APPLICATION TAG MASK 

27 

(LSB) 

28 

(MSB) TRANSFER LENGTH 

31 

(LSB) 


See the READ (10) command for the definitions of the GROUP NUMBER field, the RDPROTECT field, the 
DPO bit, the FUA bit, the FUA_NV bit, the LOGICAL BLOCK ADDRESS field, and the TRANSFER LENGTH 
field. 
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When checking of the LOGICAL BLOCK REFERENCE TAG field is enabled (see table 86 in 3.20), the 
EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG field contains the value of the LOGICAL BLOCK 
REFERENCE TAG field expected in the protection information of the first logical block accessed by the com¬ 
mand instead of a value based on the LBA. 

ATO bit 

If the ATO bit is set to one in the Control mode page (see SPC-4) and checking of the LOGICAL BLOCK APPLICATION 
TAG field is enabled (see table 86 in 3.20), the LOGICAL BLOCK APPLICATION TAG MASK field contains a value that is a 
bit mask for enabling the checking of the LOGICAL BLOCK APPLICATION TAG field in the protection information for each 
logical block accessed by the command. A LOGICAL BLOCK APPLICATION TAG MASK field bit set to one enables the 
checking of the corresponding bit of the EXPECTED LOGICAL BLOCK APPLICATION TAG field with the corresponding bit 
of the LOGICAL BLOCK APPLICATION TAG field in the protection information. 

If the ATO bit is set to one in the Control mode page (see SPC-4) and checking of the LOGICAL BLOCK APPLICATION 
TAG field is disabled (see table 86 in 3.20), or if the ATO bit is set to zero, the LOGICAL BLOCK APPLICATION TAG MASK 
field and the EXPECTED LOGICAL BLOCK APPLICATION TAG field shall be ignored. 
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3.24 


READ BUFFER command 


3.24.1 READ BUFFER command introduction 

The READ BUFFER command (see table 91) is used in conjunction with the WRITE BUFFER command as a 
diagnostic function for testing memory in the SCSI device and the integrity of the service delivery subsystem. 
This command shall not alter the medium. 

Table 91 — READ BUFFER command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (3Ch) 

1 

Reserved MODE 

2 

BUFFER ID 

3 

(MSB) BUFFER OFFSET 

4 

(LSB) 

5 

(MSB) ALLOCATION LENGTH 

6 

(LSB) 

7 

CONTROL 


MODE field 

The function of this command and the meaning of fields within the CDB depend on the contents of the mode field. The 
mode field is defined in table 92. 

Table 92 — READ BUFFER MODE field 


MODE 

Description 

OOh 

Combined header and data a 

Olh 

Vendor specific a 

02 h 

Data 

03h 

Descriptor 

OAh 

Echo buffer 

OBh 

Echo buffer descriptor 

1 Ah 

Enable expander communications protocol and Echo buffer 

04h - 09h 

Reserved 

OCh-19h 

Reserved 

IBh-IFh 

Reserved 

a Modes OOh and Olh are not recommended. 


If the mode is not set to one, the ALLOCATION LENGTH field is defined in 2.1.4.5. 

Note. a Combined header and data mode (OOh) In this mode, a four-byte header followed by data bytes is 
returned to the application client in the Data-In Buffer. The allocation length should be set to four or 
greater. The BUFFER ID and the BUFFER OFFSET fields are reserved. 
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The four-byte READ BUFFER header (see table 93) is followed by data bytes from the buffer. 

Table 93 — READ BUFFER header 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

Reserved 

1 

(MSB) BUFFER CAPACITY 

3 

(LSB) 

4 

DATA 

n 



BUFFER CAPACITY field 

The BUFFER CAPACITY field specifies the total number of data bytes available in the buffer. The buffer capacity is not 
reduced to reflect the actual number of bytes written using the WRITE BUFFER command. The relationship between the 
BUFFER CAPACITY field and the CDB ALLOCATION LENGTH field is defined in 2.1.4.5. Following the READ BUFFER 
header, the device server shall transfer data from the buffer. 

3.24.1.1 Vendor specific mode (01 h) 

In this mode, the meanings of the BUFFER ID, BUFFER OFFSET, and ALLOCATION LENGTH fields are not 
specified by the standard. 

3.24.1.2 Data mode (02h) 

In this mode, the Data-In Buffer is filled only with logical unit buffer data. The BUFFER ID field specifies a buffer 
within the logical unit from which data shall be transferred. Seagate assigns buffer ID codes to buffers within 
the logical unit. Buffer ID zero shall be supported. If more than one buffer is supported, then additional buffer ID 
codes shall be assigned contiguously, beginning with one. Buffer ID code assignments for the READ BUFFER 
command shall be the same as for the WRITE BUFFER command. If an unsupported buffer ID code is 
selected, then the command shall be terminated with CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 

The buffer offset field contains the byte offset within the specified buffer from which data shall be trans¬ 
ferred. The application client should conform to the offset boundary requirements returned in the READ 
BUFFER descriptor (see 3.24.1.3). If the device server is unable to accept the specified buffer offset, the com¬ 
mand shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and 
the additional sense code set to INVALID FIELD IN CDB. 

3.24.1.3 Descriptor mode (03h) 

In this mode, a maximum of four bytes of READ BUFFER descriptor information is returned. The device server 
shall return the descriptor information for the buffer specified by the BUFFER ID field (see the description of the 
buffer ID in 3.24.1.2). If there is no buffer associated with the specified buffer ID, the device server shall return 
all zeros in the READ BUFFER descriptor. The BUFFER OFFSET field is reserved in this mode. The allocation 
length should be set to four or greater. The READ BUFFER descriptor is defined as shown in table 94. 

OFFSET BOUNDARY field 

The OFFSET BOUNDARY field returns the boundary alignment within the selected buffer for subsequent WRITE BUFFER 
and READ BUFFER commands. The value contained in the offset boundary field shall be interpreted as a power of two. 
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Table 94 — READ BUFFER descriptor 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

OFFSET BOUNDARY 

1 




BUFFER CAPACITY 




3 










BUFFER OFFSET field 

The value contained in the BUFFER OFFSET field of subsequent WRITE BUFFER and READ BUFFER com¬ 
mands should be a multiple of 2 0ffset boundary as shown in table 95. 

Table 95 — Buffer offset boundary 


Offset boundary 

20ffset boundary 

Buffer offsets 

Oh 

2°= 1 

Byte boundaries 

1h 

2 1 =2 

Even-byte boundaries 

2h 

22 = 4 

Four-byte boundaries 

3h 

23 = 8 

Eight-byte boundaries 

4h 

2 4 = 16 

16-byte boundaries 

FFh 

Not applicable 

0 is the only supported buffer offset 


BUFFER CAPACITY field 

The BUFFER CAPACITY field shall return the size of the selected buffer in bytes. 

Note. In a system employing multiple application clients, a buffer may be altered between the WRITE 
BUFFER and READ BUFFER commands by another application client. Buffer testing applications 
should ensure that only a single application client is active. Use of reservations to all logical units 
on the device or linked commands may be helpful in avoiding buffer alteration between these two 
commands. 

3.24.1.4 Echo buffer mode (OAh) 

In this mode the device server transfers data to the application client from the echo buffer that was written by 
the most recent WRITE BUFFER command with the mode field set to echo buffer received on the same I T 
nexus. The READ BUFFER command shall return the same number of bytes of data as received in the prior 
WRITE BUFFER command with the mode field set to echo buffer, limited by the allocation length. The 
BUFFER ID and BUFFER OFFSET fields are ignored in this mode. 

If no WRITE BUFFER command with the mode set to echo buffer received on this l_T nexus has completed 
without an error, then the READ BUFFER command shall terminate with CFIECK CONDITION status, with the 
sense key set to ILLEGAL REQUEST, and the additional sense code set to COMMAND SEQUENCE ERROR. 
If the data in the echo buffer has been overwritten by another l_T nexus, the READ BUFFER command shall 
be terminated with CFIECK CONDITION status, with the sense key set to ABORTED COMMAND, and the 
additional sense code set to ECHO BUFFER OVERWRITTEN. 

After a WRITE BUFFER command with the mode set to echo buffer has completed without an error, the appli¬ 
cation client may send multiple READ BUFFER commands with the mode set to echo buffer in order to read 
the echo buffer data multiple times. 
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3.24.1.5 Echo buffer descriptor mode (OBh) 


In this mode, a maximum of four bytes of READ BUFFER descriptor information is returned. The device server 
shall return the descriptor information for the echo buffer. If there is no echo buffer implemented, the device 
server shall return all zeros in the READ BUFFER descriptor. The BUFFER ID field and buffer offset field 
are reserved in this mode. The allocation length should be set to four or greater. The READ BUFFER descrip¬ 
tor is defined as shown in table 96. 


Table 96 — Echo buffer descriptor 


Bit 

Byte 

7 6 5 4 3 2 1 

0 

0 

Reserved 

EBOS 

1 

Reserved 

2 

Reserved (MSB) 

3 

BUFFER CAPACITY (LSB) 


BUFFER CAPACITY field 

The BUFFER CAPACITY field shall return the size of the echo buffer in bytes aligned to a four-byte boundary. The maxi¬ 
mum echo buffer size is 4 096 bytes. 

If the echo buffer is implemented, the echo buffer descriptor shall be implemented. 

EBOS bit 

1 An echo buffer overwritten supported (EBOS) bit set to one indicates either: 

a) The device server returns the ECHO BUFFER OVERWRITTEN additional sense code if the data being read 
from the echo buffer is not the data previously written by the same l_T nexus, or 

b) The device server ensures echo buffer data returned to each l_T nexus is the same as that previously written 
by that l_T nexus. 

0 An EBOS bit set to zero specifies that the echo buffer may be overwritten by any intervening command received on 
any l_T nexus. 

A READ BUFFER command with the mode set to echo buffer descriptor may be used to determine the echo 
buffer capacity and supported features before a WRITE BUFFER command with the mode set to echo buffer is 
sent. 

3.24.1.6 Enable expander communications protocol and Echo buffer (1Ah) 

Receipt of a READ BUFFER command with this mode (1 Ah) causes a communicative expander (see SPI-5) to 
enter the expanded communications protocol mode. Device servers in SCSI target devices that receive a 
READ BUFFER command with this mode shall process it as if it were a READ BUFFER command with mode 
OAh (see 3.24.1.4). 
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3.25 


READ CAPACITY (10) command 


3.25.1 READ CAPACITY (10) overview 

The READ CAPACITY (10) command (see table 97) requests that the device server transfer 8 bytes of 
parameter data describing the capacity and medium format of the direct-access block device to the data-in 
buffer. This command may be processed as if it has a HEAD OF QUEUE task attribute. If the logical unit 
supports protection information, the application client should use the READ CAPACITY (16) command instead 
of the READ CAPACITY (10) command. 

Table 97 — READ CAPACITY (10) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (25h) 

1 

Reserved Obsolete 

2 

(MSB) LOGICAL BLOCK ADDRESS 

5 

(LSB) 

6 

Reserved 

7 


8 

Reserved PMI 

9 

CONTROL 


See clause 2.1.4 for the definition of the LOGICAL BLOCK ADDRESS field. 

LOGICAL BLOCK ADDRESS field 

The LOGICAL BLOCK ADDRESS field shall be set to zero if the PMI bit is set to zero. If the PMI bit is set to zero and the 
LOGICAL BLOCK ADDRESS field is not set to zero, the device server shall terminate the command with CHECK CONDI¬ 
TION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 

PMI (Partial Medium Indicator) bit 

0 A partial medium indicator (PMI) bit set to zero specifies that the device server return information on the last logical 
block on the direct-access block device. 

1 A PMI bit set to one specifies that the device server return information on the last logical block after that specified in 
the LOGICAL BLOCK ADDRESS field before a substantial vendor-specific delay in data transfer may be encoun¬ 
tered. 

This function is intended to assist storage management software in determining whether there is sufficient 
space starting with the logical block address specified in the CDB to contain a frequently accessed data struc¬ 
ture (e.g., a file directory or file index) without incurring an extra delay. 
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3.25.2 READ CAPACITY (10) parameter data 

The READ CAPACITY (10) parameter data is defined in table 98. Any time the READ CAPACITY (10) 
parameter data changes, the device server should establish a unit attention condition as described in. 

Table 98 — READ CAPACITY (10) parameter data 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

(MSB) 


RETURNED LOGICAL BLOCK ADDRESS 


3 







(LSB) 

4 

(MSB) 


BLOCK LENGTH IN BYTES 


7 







(LSB) 


RETURNED LOGICAL BLOCK ADDRESS field 

If the number of logical blocks exceeds the maximum value that is able to be specified in the RETURNED LOGICAL 
BLOCK ADDRESS field, the device server shall set the RETURNED LOGICAL BLOCK ADDRESS field to FFFFFFFFh. 
The application client should then issue a READ CAPACITY (16) command (see 3.27) to retrieve the READ CAPACITY 
(16) parameter data. 

0 If the PMI bit is set to zero, the device server shall set the RETURNED LOGICAL BLOCK ADDRESS field to the 
lower of: 

a) the LBA of the last logical block on the direct-access block device; or 

b) FFFFFFFFh. 

1 If the PMI bit is set to one, the device server shall set the returned logical block address field to the lower of: 

a) the last LBA after that specified in the LOGICAL BLOCK ADDRESS field of the CDB before a substantial ven¬ 
dor-specific delay in data transfer may be encountered; or 

b) FFFFFFFFh. 

The RETURNED LOGICAL BLOCK ADDRESS shall be greater than or equal to that specified by the LOGICAL BLOCK 
ADDRESS field in the CDB. 

BLOCK LENGTH IN BYTES field 

The BLOCK LENGTH IN BYTES field contains the number of bytes of user data in the logical block indicated by the 
RETURNED LOGICAL BLOCK ADDRESS field. This value does not include protection information or additional informa¬ 
tion (e.g., ECC bytes) recorded on the medium. 
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3.26 


READ CAPACITY (16) command 


3.26.1 READ CAPACITY (16) command overview 

The READ CAPACITY (16) command (see table 99) requests that the device server transfer parameter data 
describing the capacity and medium format of the direct-access block device to the data-in buffer. This com¬ 
mand is mandatory if the logical unit supports protection information and optional otherwise (see SBC-4). This 
command is implemented as a service action of the SERVICE ACTION IN operation code. This command may 
be processed as if it has a HEAD OF QUEUE task attribute. 


Table 99 — READ CAPACITY (16) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (9Eh) 

1 

Reserved SERVICE ACTION (1 Oh) 

2 

(MSB) LOGICAL BLOCK ADDRESS 

9 

(LSB) 

10 

(MSB) ALLOCATION LENGTH 

13 

(LSB) 

14 

Reserved PMI 

15 

CONTROL 


LOGICAL BLOCK ADDRESS field 

See clause 2.1.4 for the definition of the LOGICAL BLOCK ADDRESS field. 

See the READ CAPACITY (10) command (see 3.25) for the definition of the PMI bit. 

ALLOCATION LENGTH field 

The ALLOCATION LENGTH field specifies the maximum number of bytes that the application client has allocated for 
returned parameter data. An allocation length of zero indicates that no data shall be transferred. This condition shall not be 
considered as an error. The device server shall terminate transfers to the data-in buffer when the number of bytes specified 
by the ALLOCATION LENGTH field have been transferred or when all available data has been transferred, whichever is 
less. The contents of the parameter data shall not be altered to reflect the truncation, if any, that results from an insufficient 
allocation length. 
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3.26.2 READ CAPACITY (16) parameter data 

The READ CAPACITY (16) parameter data is defined in table 100. Anytime the READ CAPACITY (16) 
parameter data changes, the device server should establish a unit attention condition as described in SPC-4. 

Table 100 — READ CAPACITY (16) parameter data 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

(MSB) RETURNED LOGICAL BLOCK ADDRESS 

7 

(LSB) 

8 

(MSB) BLOCK LENGTH IN BYTES 

11 

(LSB) 

12 

Reserved P_TYPE PROT_EN 

13 

Reserved 

31 



RETURNED LOGICAL BLOCK ADDRESS 

The RETURNED LOGICAL BLOCK ADDRESS field and BLOCK LENGTH IN BYTES field of the READ CAPACITY (16) 
parameter data are the same as the in the READ CAPACITY (10) parameter data (see 3.25.1). The maximum value that 
shall be returned in the RETURNED LOGICAL BLOCK ADDRESS field is FFFFFFFF_FFFFFFFEh. 

P TYPE (Protection Type) field 

The protection type (P_TYPE) field and the PROT_EN bit (see table 15) indicate the logical unit’s current type 
of protection. 

Table 101 — P_TYPE field and PROT EN bit 


PROT EN 

PTYPE 

DESCRIPTION 

0 

XXXb 

The logical unit is formatted to type 0 protection 

1 

000b 

The logical unit is formatted to type 1 protection 

1 

001b 

The logical unit is formatted to type 2 protection 

1 

010b 

The logical unit is formatted to type 3 protection 

1 

011b- 111b 

Reserved 
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3.27 


READ DEFECT DATA (10) command 


3.27.1 READ DEFECT DATA (10) command overview 

The READ DEFECT DATA (10) command (see table 102) requests that the device server transfer the medium 
defect data to the data-in buffer. 

Table 102 — READ DEFECT DATA (10) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (37h) 

1 

Reserved 

2 

Reserved REQ_PLIST REQJ3LIST DEFECT LIST FORMAT 

3 

Reserved 

6 


7 

(MSB) ALLOCATION LENGTH 

8 

(LSB) 

9 

CONTROL 


If the device server is unable to access the medium defect data, it shall terminate the command with CHECK 
CONDITION status. The sense key shall be set to either MEDIUM ERROR, if a medium error occurred, or NO 
SENSE, if medium defect data does not exist. The additional sense code shall be set to DEFECT LIST NOT 
FOUND. 

Note. Some device servers may not be able to return medium defect data until after a FORMAT UNIT 
command (see 3.5) has been completed successfully. 

REQ_PLIST (request primary defect list) bit 

0 A request primary defect list (REQ_PLIST) bit set to zero specifies that the device server shall not return the PLIST. 
1 A REQPLIST bit set to one specifies that the device server shall return the PLIST, if any. 

REQ_GLIST (request grown defect list) bit 

0 A request grown defect list (REQ GLIST) bit set to zero specifies that the device server shall not return the GLIST. 
1 A REQ_GLIST bit set to one specifies that the device server shall return the GLIST, if any. 

A REQ_PLIST bit set to zero and a REQ_GLIST bit set to zero specifies that the device server shall return only 
the defect list header (i.e., the first four bytes of the defect list). 

A REQ_PLIST bit set to one and a REQ_GLIST bit set to one specifies that the device server shall return both 
the PLIST and GLIST, if any. The order the lists are returned in is vendor-specific. Whether the lists are merged 
or not is vendor-specific. 

DEFECT LIST FORMAT field 

The DEFECT LIST FORMAT field specifies the preferred format for the defect list. This field is intended for those device 
servers capable of returning more than one format, as defined in the FORMAT UNIT command (see 3.5.5). A device server 
unable to return the requested format shall return the defect list in its default format and indicate that format in the DEFECT 
LIST FORMAT field in the defect list header (see table 103). 
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If the requested defect list format and the returned defect list format are not the same, the device server shall 
transfer the defect data and then terminate the command with CHECK CONDITION status with the sense key 
set to RECOVERED ERROR and the additional sense code set to DEFECT LIST NOT FOUND. 

ALLOCATION LENGTH field 

The ALLOCATION LENGTH field is defined in the READ CAPACITY (16) command (see 3.27). The application client is 
responsible for comparing the allocation length requested in the CDB with the defect list length returned in the parameter 
data to determine whether a partial list was received. If the number of address descriptors the device server has to report 
exceeds the maximum value that is able to be specified in the ALLOCATION LENGTH field, the device server shall transfer 
no data and return CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense 
code set to INVALID FIELD IN CDB. 

3.27.2 READ DEFECT DATA (10) parameter data 

The READ DEFECT DATA (10) parameter data (see table 103) contains a four-byte header, followed by zero 
or more address descriptors. 


Table 103 — READ DEFECT DATA (10) parameter data 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

Reserved 

1 

Reserved PLISTV GLISTV DEFECT LIST FORMAT 

2 

(MSB) DEFECT LIST LENGTH (N - 3) 

3 

(LSB) 

Defect list (if any) 

4 

ADDRESS DESCRIPTOR(S) (IF ANY) 

" 



PLISTV (PLIST valid) bit 

0 A PLIST valid (PLISTV) bit set to zero indicates that the data returned does not contain the PLIST. 

1 A PLISTV bit set to one indicates that the data returned contains the PLIST. 

GLISTV (GLIST valid) bit 

0 A GLIST valid (GLISTV) bit set to zero indicates that the data returned does not contain the GLIST. 

1 A GLISTV bit set to one indicates that the data returned contains the GLIST. 

DEFECT LIST FORMAT field 

The DEFECT LIST FORMAT field indicates the format of the address descriptors returned by the device server. This field is 
defined in the FORMAT UNIT command. 

If the device server returns short block format address descriptors or long block format address descriptors, 
the address descriptors contain vendor-specific values. 

Note. The use of the short block format and the long block format is not recommended for this command. 
There is no standard model that defines the meaning of the block address of a defect. In the usual 
case, a defect that has been reassigned no longer has an LBA. 
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If the device server returns physical sector format address descriptors, it may or may not include defects in 
parts of the medium not accessible to the application client. If the device server returns bytes from index format 
address descriptors, it shall return a complete list of the defects. A complete list of the defects may include 
defects in areas not within the capacity returned in the READ CAPACITY command. 

The DEFECT LIST LENGTH field indicates the length in bytes of the address descriptors that follow. The 
DEFECT LIST LENGTH is equal to four or eight times the number of the address descriptors, depending on 
the format of the returned address descriptors. 

The address descriptors may or may not be sent in ascending order. 
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3.28 READ DEFECT DATA (12) command 
0.0.1 READ DEFECT DATA (12) command overview 

The READ DEFECT DATA (12) command (see Table 104) requests that the device server transfer the medium 
defect data to the data-in buffer. 


Table 104 — READ DEFECT DATA (12) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (B7h) 

1 

Reserved REQ_PLIST REQ_GLIST DEFECT LIST FORMAT 

2 

Reserved 

5 


6 

(MSB) ALLOCATION LENGTH 

9 

(LSB) 

10 

Reserved 

11 

CONTROL 


See the READ DEFECT DATA (10) command (see 3.27) for the definitions of the fields in this command. 

Note. The application client may determine the length of the defect list by sending the READ DEFECT 
DATA (12) command with an ALLOCATION LENGTH field set to eight. The device server returns 
the defect list header that contains the length of the defect list. 
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0.0.2 READ DEFECT DATA (12) parameter data 

The READ DEFECT DATA (12) parameter data (see table 105) contains an eight byte header, followed by zero 
or more address descriptors. 

Table 105 — READ DEFECT DATA (12) parameter data 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

Reserved 

1 

Reserved PLISTV GLISTV DEFECT LIST FORMAT 

2 

Reserved 

3 

Reserved 

4 

(MSB) DEFECT LIST LENGTH (N - 7) 

7 

(LSB) 


Defect list (if any) 


8 

ADDRESS DESCRIPTOR(S) (IF ANY) 

n 



See the READ DEFECT DATA (10) command (see 3.27) for the definitions of the fields in the defect list. 
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3.29 


READ LONG (10) command 


The READ LONG (10) command (see table 106) requests that the device server transfer data from a single 
logical block to the data-in buffer. The data transferred during the READ LONG (10) command is vendor-spe¬ 
cific, but shall include the following items recorded on the medium: 

(a) user data or transformed user data; 

(b) protection information or transformed protection information, if any; and 

(c) any additional information (e.g., ECC bytes). 

If a cache contains a more recent version of a logical block, the device server shall write the logical block to the 
medium before reading it. The values in the Read-Write Error Recovery mode page (see 4.3.16) do not apply 
to this command. The device server may perform retries while processing this command. 

Table 106 — READ LONG (10) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (3Eh) 

1 

Reserved CORRCT Obsolete 

2 

(MSB) LOGICAL BLOCK ADDRESS 

5 

(LSB) 

6 

Reserved 

7 

(MSB) BYTE TRANSFER LENGTH 

8 

(LSB) 

9 

CONTROL 


LOGICAL BLOCK ADDRESS field 

See clause 2.1.4 for the definition of the LOGICAL BLOCK ADDRESS field. 

If the additional information contain an ECC, any other additional bytes that are correctable by ECC should be 
included (e.g., a data synchronization mark within the area covered by ECC). It is not required for the ECC 
bytes to be at the end of the user data or protection information, if any; however, the ECC bytes should be in 
the same order as they are on the medium. 

CORRCT (correct) bit 

0 A correct (CORRCT) bit set to zero specifies that a logical block be read without any correction made by the device 
server. A CORRCT bit set to zero should result in GOOD status unless data is not transferred for some reason other 
than that the data is non-correctable. In this case the appropriate status and sense data shall be returned. 

1 A CORRCT bit set to one specifies that the data be corrected by ECC before being transferred to the data-in buffer. 

BYTE TRANSFER LENGTH field 

The BYTE TRANSFER LENGTH field specifies the number of bytes of data that shall be read from the specified logical 
block and transferred to the data-in buffer. If the BYTE TRANSFER LENGTH field is not set to zero and does not match the 
available data length, the device server shall terminate the command with CHECK CONDITION status with the sense key 
set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. In the sense data (see SPC-4), 
the VALID and ILI bits shall each be set to one and the INFORMATION field shall be set to the difference (i.e., residue) of 
the requested byte transfer length minus the actual available data length in bytes. Negative values shall be indicated by 
two's complement notation. 


SCSI Commands Reference Manual, Rev. A 


135 




A BYTE TRANSFER LENGTH field set to zero specifies that no bytes shall be read. This condition shall not be considered 
an error. 

3.30 READ LONG (16) command 

The READ LONG (16) command (see table 107) requests that the device server transfer data from a single 
logical block to the data-in buffer. The data transferred during the READ LONG (16) command is vendor-spe¬ 
cific, but shall include the following items recorded on the medium: 

(a) user data or transformed user data; 

(b) protection information or transformed protection information, if any; and 

(c) any additional information (e.g., ECC bytes). 

If a cache contains a more recent version of a logical block, the device server shall write the logical block to the 
medium before reading it. The values in the Read-Write Error Recovery mode page (see 4.3.16) do not apply 
to this command. The device server may perform retries while processing this command. This command is 
implemented as a service action of the SERVICE ACTION IN operation code. 

Table 107 — READ LONG (16) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (9Eh) 

1 

Reserved SERVICE ACTION (11 h) 

2 

(MSB) LOGICAL BLOCK ADDRESS 

9 

(LSB) 

10 

Reserved 

11 


12 

(MSB) BYTE TRANSFER LENGTH 

13 

(LSB) 

14 

Reserved CORRCT 

15 

CONTROL 


See the READ LONG (10) command (see 3.29) for the definitions of the fields in this command. 
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3.31 


REASSIGN BLOCKS command 


3.31.1 REASSIGN BLOCKS command overview 

The REASSIGN BLOCKS command (see table 108) requests that the device server reassign defective logical 
blocks to another area on the medium set aside for this purpose. The device server should also record the 
location of the defective logical blocks in the GUST, if supported. This command shall not alter the contents of 
the PLIST. 

The parameter list provided in the data-out buffer contains a defective LBA list that contains the LBAs of the 
logical blocks to be reassigned. The device server shall reassign the parts of the medium used for each logical 
block in the defective LBA list. More than one physical block may be relocated by each LBA. If the device 
server is able to recover user data and protection information, if any, from the original logical block, it shall write 
the recovered user data and any protection information to the reassigned logical block. If the device server is 
unable to recover user data and protection information, if any, it shall write vendor-specific data as the user 
data and shall write a default value of FFFFFFFF_FFFFFFFFh as the protection information, if enabled. The 
data in all other logical blocks on the medium shall be preserved. 

Note. The effect of specifying a logical block to be reassigned that previously has been reassigned is to 
reassign the logical block again. Although not likely, over the life of the medium, a logical block may 
be assigned to multiple physical block addresses until no more spare locations remain on the 
medium. 


Table 108 — REASSIGN BLOCKS command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (07h) 

1 

Reserved LONGLBA LONGLIST 

2 

Reserved 

4 


5 

CONTROL 


LONGLBA (Long LBA) bit 

0 A long LBA (LONGLBA) bit set to zero specifies that the REASSIGN BLOCKS defective LBA list contains four byte 
LBAs. 

1 A LONGLBA bit set to one specifies that the REASSIGN BLOCKS defective LBA list contains eight byte LBAs. 
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3.31.2 


REASSIGN BLOCKS parameter list 


The REASSIGN BLOCKS parameter list (see table 109) contains a four-byte parameter list header followed by 
a defective LBA list containing one or more LBAs. 

Table 109 — REASSIGN BLOCKS parameter list 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

Parameter list header (see table 110 or table 111) 

3 


4 

DEFECTIVE LBA LIST (if any) 

" 



LONGLIST bit 

0 If LONGLIST is set to zero, the parameter list header is defined in table 110. 

Table 110 — REASSIGN BLOCKS short parameter list header 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

1 

Reserved 

2 

(MSB) DEFECT LIST LENGTH 


3 (LSB) 


1 If LONGLIST is set to one, the parameter list header is defined in table 111. 

Table 111 — REASSIGN BLOCKS long parameter list header 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

(MSB) 



DEFECT LIST LENGTH 


3 







(LSB) 


DEFECT LIST LENGTH field 

The DEFECT LIST LENGTH field indicates the total length in bytes of the DEFECTIVE LBA LIST field. The DEFECT LIST 
LENGTH field does not include the parameter list header length and is equal to either: 

a) four times the number of LBAs, if the LONGLBA bit is set to zero; or 

b) eight times the number of LBAs, if the LONGLBA bit is set to one. 

DEFECTIVE LBA LIST field 

The DEFECTIVE LBA LIST field contains a list of defective LBAs. Each LBA is a four-byte field if the LONGLBA bit is set to 
zero or an eight-byte field if the LONGLBA bit is set to one. The LBAs shall be in ascending order. 
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If the direct-access block device has insufficient capacity to reassign all of the specified logical blocks, the 
device server shall terminate the command with CHECK CONDITION status with the sense key set to HARD¬ 
WARE ERROR and the additional sense code set to NO DEFECT SPARE LOCATION AVAILABLE. 

If the direct-access block device is unable to successfully complete a REASSIGN BLOCKS command, the 
device server shall terminate the command with CHECK CONDITION status with the appropriate sense data 
(see SPC-4). The first LBA not reassigned shall be returned in the COMMAND-SPECIFIC INFORMATION field 
of the sense data. If information about the first LBA not reassigned is not available, or if all the defects have 
been reassigned, the command-specific information field shall be set to FFFFFFFFh if fixed format sense 
data is being used or FFFFFFFF_FFFFFFFFh if descriptor format sense data is being used. 

If the REASSIGN BLOCKS command failed due to an unexpected unrecoverable read error that would cause 
the loss of data in a logical block not specified in the defective LBA list, the LBA of the unrecoverable block 
shall be returned in the information field of the sense data and the valid bit shall be set to one. 

If the REASSIGN BLOCKS command returns CHECK CONDITION status and the sense data COMMAND- 
SPECIFIC INFORMATION field contains a valid LBA, the application client should remove all LBAs from the 
defective LBA list prior to the one returned in the COMMAND-SPECIFIC INFORMATION field. If the sense key 
is MEDIUM ERROR and the information field contains the valid LBA, the application client should insert that 
new defective LBA into the defective LBA list and reissue the REASSIGN BLOCKS command with the new 
defective LBA list. Otherwise, the application client should perform any corrective action indicated by the sense 
data and then reissue the REASSIGN BLOCKS command with the new defective LBA list. 
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3.32 


RECEIVE DIAGNOSTIC RESULTS command 


The RECEIVE DIAGNOSTIC RESULTS command (see table 112) requests analysis data be sent to the appli¬ 
cation client Data-In Buffer after completion of a SEND DIAGNOSTIC command (see 3.43), or, optionally, 
SCSI-3 Enclosure Services (SES) pages be sent to the initiator. Support for SES is indicated in the drive prod¬ 
uct manual. The drive supports the optional Page format, wherein the initiator sends additional pages after a 
SEND DIAGNOSTIC command. These additional pages have a page code that specifies to the drive the for¬ 
mat of the data to be returned after it receives a RECEIVE DIAGNOSTIC RESULTS command. 

If no data in the optional Page format was requested by the SEND DIAGNOSTICS command (0 in bit 4 of Table 
134), the data returned to the initiator is in the format shown in Table 113. 

If the SEND DIAGNOSTICS command requested either page OOh or page 40h (the only two optional pages 
supported by the drive), data returned is in the format shown in Table 178 or 179, respectively. 

All FRU and error code definitions are unique to this product and intended for factory/field maintenance per¬ 
sonnel. 

The drive supports the optional Page format, wherein the initiator sends additional pages after a SEND DIAG¬ 
NOSTIC command. These additional pages have a page code that specifies to the drive the format of the data 
to be returned after it receives a RECEIVE DIAGNOSTIC RESULTS command. 


Table 112 — RECEIVE DIAGNOSTIC RESULTS command 


Bit 

Byte 

7 6 5 4 3 2 1 0 


OPERATION CODE (1 Ch) 


Reserved PCV 


PAGE CODE 


(MSB) ALLOCATION LENGTH 


(LSB) 


CONTROL 


PCV (Page Code Valid) bit 

0 A page code valid (PCV) bit set to zero specifies that the device server return parameter data based on the most 
recent SEND DIAGNOSTIC command (e.g., the diagnostic page with the same page code as that specified in the 
most recent SEND DIAGNOSTIC command). The response to a RECEIVE DIAGNOSTIC RESULTS command with 
the PCV bit set to zero is vendor-specific if: 

a) The most recent SEND DIAGNOSTIC command was not a SEND DIAGNOSTIC command defining parameter 
data to return; 

b) A RECEIVE DIAGNOSTIC RESULTS command with a PCV bit set to one has been processed since the last 
SEND DIAGNOSTIC command was processed; or 

c) No SEND DIAGNOSTIC command defining parameter data to return has been processed since power on, 
hard reset, or logical unit reset. 

1 A page code valid (PCV) bit set to one specifies that the device server return the diagnostic page specified in the 
PAGE CODE FIELD. Page code values are defined in Table 177. 

NOTES 

(a) Logical units compliant with previous versions of SPC-4 may transfer more than one diagnostic page in 
the parameter data if the PCV bit is set to zero and the previous SEND DIAGNOSTIC command sent 
more than one diagnostic page in the parameter list. 
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(b) To ensure that the diagnostic command information is not destroyed by a command sent from another 
l_T nexus, the logical unit should be reserved. 

(c) Although diagnostic software is generally device-specific, this command and the SEND DIAGNOSTIC 
command provide a means to isolate the operating system software from the device-specific diagnos¬ 
tic software. The operating system may remain device-independent. 

PAGE CODE field 

The PAGE CODE field identifies which diagnostic page is requested as a result of a RECEIVE DIAGNOSTIC RESULTS 
command with the PCV bit equal to one, or returned as a result of a RECEIVE DIAGNOSTIC RESULTS parameter data. 

ALLOCATION LENGTH field 

The ALLOCATION LENGTH shall specify the number of bytes the initiator has allocated for returned data. An ALLOCA¬ 
TION LENGTH of zero indicates that no data shall be transferred. Any other value indicates the maximum number of bytes 
that shall be transferred. The drive terminates the DATA IN phase when ALLOCATION LENGTH bytes have been trans¬ 
ferred or when all available data has been transferred to the initiator, whichever is less. 


Table 113 — Diagnostic Data Bytes 


Code 

Byte 

Description 

OOh 

0 

ADDITIONAL LENGTH (MSB) [1] 

28h 

1 

ADDITIONAL LENGTH (LSB) [1] 

XXh 

2 

FRU CODE (most probable) [2] 

XXh 

3 

FRU CODE [2] 

XXh 

4 

FRU CODE [2] 

XXh 

5 

FRU CODE (least probable) [2] 

XXh 

6 

ERROR CODE (MSB) [3] 

V.U. 

7 

ERROR CODE (LSB) [4] 

V.U. 

8 thru n 

ADDITIONAL VENDOR UNIQUE FAULT INFORMATION (not available) 


[1] ADDITIONAL LENGTH. This two byte value indicates the number of additional bytes included in the diag¬ 
nostic data list. For example, if no product unique byte (byte 7) is available, this value would be 0006h. A 
value of OOOOh means that there are no additional bytes. 

[2] A FIELD REPLACEABLE UNIT (FRU) Code is a byte that identifies an assembly that may have failed. 
The codes will be listed in probability order, with the most probable assembly listed first and the least 
probable listed last. A code of OOh indicates there is no FRU information and a code of 01 h indicates the 
entire unit should be replaced. Seagate drives return OOh in these bytes. 

[3] The ERROR CODE is a two byte value that provides information designating which part of a diagnostic 
operation has failed. The byte 7 error code is vendor unique and defined in note [4], Usually, Seagate 
drives support only some subset of the list given in note [4], 

[4] Vendor Unique codes supported by Seagate devices. 

Diagnostic Fault Codes 

01 h Formatter Diagnostic Error 

02h Microprocessor RAM Diagnostic Error 

04h No Drive Ready 

08h No Sector or Index Detected 

09h Fatal Hardware Error While Doing Drive Diagnostics 
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Diagnostic Fault Codes 


OCh No Drive Command Complete 

lOh Unable to Set Drive Sector Size 

14h Unable to Clear Drive Attention 

18h Unable to Start Spindle Motor 

20h Unable to Recal Drive 

30h Unable to Send Write Current Data to Drive 

34h Unable to Issue Drive SEEK Command 

40h Unable to Read User Table From Drive 

41 h Ran Out of Sectors While Doing Drive Diagnostics 

42h Unable to Read Reallocation Table 

43h Unable to Read ETF Log 

45h Firmware Read from Disc or Sent by Host has an Invalid Checksum 

60h Thermal Calibration Failure 

70h Microprocessor Internal Timer Error 

80h Buffer Controller Diagnostic Error 

81 h Buffer RAM Diagnostic Error 

Clh Data Miscompare While Doing Drive Diagnostics 
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3.33 


RELEASE(6) command 


This command has been declared obsolete by the T10 committee. However, it is included because it 
may be implemented on some products. 

The RELEASE(6) command (see table 114) is used to release a previously reserved logical unit. This sub¬ 
clause describes only those instances where the RELEASE(6) command differs from the RELEASE(IO) com¬ 
mand. Except for the instances described in this subclause, the RELEASE(6) command shall function exactly 
like the RELEASE(IO) command (see 3.35). 


Table 114 — RELEASED) Command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (17h) 

1 

Reserved Obsolete 

2 

Obsolete 

3 

Reserved 

4 

Reserved 

5 

CONTROL 


The RELEASE(6) command shall not release third-party reservations. 

Obsolete Bits 1 through 4 of Byte 1 provided a method, limited to device addresses 0 through 7, to handle 
third-party reservations in earlier versions of the SCSI standard. The obsolete method has been replaced by 
the RESERVE(IO) and RELEASE(IO). 

Byte 1 Bit 0 and Byte 2 provide an obsolete way to release previously reserved extents within a logical unit. If 
Byte 1, Bit 0 is equal to one, device servers not implementing the obsolete capability shall terminate the com¬ 
mand with CHECK CONDITION status and the sense key shall be set to ILLEGAL REQUEST. 
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3.34 


RELEASE (10) command 


This command has been declared obsolete by the T10 committee. However, it is included because it 
may be implemented on some products. 


3.34.1 RELEASE(IO) command introduction 

The RELEASE(IO) command (see table 115) is used to release a previously reserved logical unit. 

Table 115 — RELEASE (10) Command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (57h) 

1 

Reserved 3RDPTY Reserved LONGID Obsolete 

2 

Obsolete 

3 

THIRD-PARTY DEVICE ID 

4 

Reserved 

5 

Reserved 

6 

Reserved 

7 

(MSB) PARAMETER LIST LENGTH 

8 

(LSB) 

9 

CONTROL 


The RESERVE and RELEASE commands provide a basic mechanism for contention resolution in multiple-ini¬ 
tiator systems. See 5.5.1 for a general description of reservations and the commands that manage them. A 
reservation may only be released by a RELEASE command from the initiator that made it. It is not an error for 
an application client to attempt to release a reservation that is not currently valid, or is held by another initiator. 
In this case, the device server shall return GOOD status without altering any other reservation. 

Byte 1 Bit 0 and Byte 2 provide an obsolete way to release previously reserved extents within a logical unit. If 
Byte 1, Bit 0 is equal to one, device servers not implementing the obsolete capability shall terminate the com¬ 
mand with CHECK CONDITION status and the sense key shall be set to ILLEGAL REQUEST. 

3.34.2 Logical unit release 

Logical unit reservation release is mandatory if the RELEASE(IO) command is implemented. This command 
shall cause the device server to terminate all non-third-party logical unit reservations that are active from the 
initiator to the specified logical unit. 

3.34.3 Third-party release 

Third-party reservation release is mandatory if the RELEASE(IO) command is implemented. Third-party 
release allows an application client to release a logical unit that was previously reserved using third-party res¬ 
ervation (see 7.21.3). Third-party release shall be implemented. It is intended for use in multiple-initiator sys¬ 
tems that use the COPY and EXTENDED COPY commands. 

If the third-party (3RDPTY) bit is zero, then a third-party release is not requested. If the 3RDPTY bit is zero 
then the LONGID bit and the PARAMETER LIST LENGTH field shall be ignored. If the 3RDPTY bit is one then 
the device server shall release the specified logical unit, but only if the initiator ID, 3RDPTY bit, and THIRD- 
PARTY DEVICE ID are identical when compared to the RESERVE command that established the reservation. 
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If the 3RDPTY bit is one the device server shall not modify the mode parameters for commands received from 
the third-party device even if the device server implements the transfer of mode parameters with a third-party 
RESERVE command. 

NOTE 26 If a target implements independent storage of mode parameters for each initiator, a third-party 
RESERVE command copies the current mode parameters for the initiator that sent the RESERVE command to 
the current mode parameters for the initiator specified as the third-party device (e.g., a copy manager SCSI 
device). A unit attention condition notifies the third-party of the changed mode parameters due to the reserva¬ 
tion. A successful third-party RELEASE command does not change the third-party devices' current mode 
parameters back to their previous values. The third-party device may issue MODE SENSE and MODE 
SELECT commands to query and modify the mode parameters. 

If the THIRD-PARTY DEVICE ID value associated with the reservation release is smaller than 255, the 
LONGID bit may be zero and the ID value sent in the CDB THIRD-PARTY DEVICE ID field. Device ID formats 
are protocol specific. If the LONGID bit is zero, the PARAMETER LIST LENGTH field shall be set to zero. If the 
THIRD-PARTY DEVICE ID is greater than 255, the LONGID bit shall be one. 

Device servers that support device IDs greater than 255 shall accept commands with LONGID equal to one. 
Device servers whose devices IDs are limited to 255 or smaller may reject commands with LONGID equal to 
one with CHECK CONDITION status and a sense key of ILLEGAL REQUEST. 

If the LONGID bit is one, the parameter list length shall be eight, and the parameter list shall have the format 
shown in table 96. If the LONGID bit is one, the THIRD-PARTY DEVICE ID field in the CDB shall be ignored. If 
the LONGID bit is one and the parameter list length is not eight, the device server shall return a CHECK CON¬ 
DITION status with a sense key of ILLEGAL REQUEST. 


Table 116 — RELEASE(IO) parameter list 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 








7 



THIRD-PARTY DEVICE ID 
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3.35 


REPORT DEVICE IDENTIFIER command 


The REPORT DEVICE IDENTIFIER command (see table 117) requests that the device server send device 
identification information to the application client. As defined in the SCC-2 standard, the REPORT DEVICE 
IDENTIFIER command is the REPORT PERIPHERAL DEVICE/COMPONENT DEVICE IDENTIFIER service 
action of the MAINTENANCE IN command. Additional MAINTENANCE IN and MAINTENANCE OUT service 
actions are defined in SCC-2 and in this standard. 

The MAINTENANCE IN service actions defined only in SCC-2 shall apply only to SCSI devices that return a 
device type of OCh or the SCCS bit set to one in their standard INQUIRY data. When a SCSI device returns a 
device type of OCh or the SCCS bit set to one in its standard INQUIRY data, the implementation requirements 
for the SCC-2 MAINTENANCE IN service actions shall be as specified in SCC-2. Otherwise the MAINTE¬ 
NANCE IN service action definitions and implementation requirements stated in this standard shall apply. 


Table 117 — REPORT DEVICE IDENTIFIER command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (A3h) 

1 

Reserved SERVICE ACTION (05h) 

2 

Reserved 

3 


4 

RESTRICTED 

5 


6 

(MSB) ALLOCATION LENGTH 

7 

(LSB) 

8 

Reserved Restricted Reserved 

9 

CONTROL 


SCC-2 defines specific usages for bytes 4 and 5, and bit 1 in byte 10, however these fields are reserved for the 
REPORT DEVICE IDENTIFIER command defined by this standard. 

The ALLOCATION LENGTH field is defined in 2.1.4.5. 


The REPORT DEVICE IDENTIFIER parameter data (see table 118) contains a four-byte field that contains the 
length in bytes of the parameter data and the logical unit's identifier. 


Table 118 — REPORT DEVICE IDENTIFIER parameter data 


Bit 

7 

6 

5 

4 

3 

2 

1 

0 

Byte 









0 

(MSB) 



IDENTIFIER LENGTH (N-3) 




3 








(LSB) 

4 

IDENTIFIER 


n 
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IDENTIFIER LENGTH field 

The IDENTIFIER LENGTH field indicates the length in bytes of the identifier field. The relationship between the IDENTI¬ 
FIER LENGTH field and the CDB ALLOCATION LENGTH field is defined in 2.1.4.5. The identifier length shall initially equal 
zero, and shall be changed only by a successful SET DEVICE IDENTIFIER command. 

IDENTIFIER field 

The IDENTIFIER field shall contain a vendor specific value. The value reported shall be the last value written by a success¬ 
ful SET DEVICE IDENTIFIER command. The value of the identifier shall be changed only by a SET DEVICE IDENTIFIER 
command. The identifier value shall persist through logical unit resets, l_T nexus losses, media format operations, and 
media replacement. 

The logical unit shall return the same identifier to all application clients. 

Processing a REPORT DEVICE IDENTIFIER may require the enabling of a nonvolatile memory within the log¬ 
ical unit. If the nonvolatile memory is not ready, the command shall be terminated with CHECK CONDITION 
status, rather than wait for the nonvolatile memory to become ready. The sense key shall be set to NOT 
READY and the additional sense code shall be set as described in table 12. This information should allow the 
application client to determine the action required to cause the device server to become ready. 
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3.36 


REPORT LUNS command 


The REPORT LUNS command (see table 119) requests that the peripheral device logical unit inventory acces¬ 
sible to the l_T nexus be sent to the application client. The logical unit inventory is a list that shall include the 
logical unit numbers of all logical units having a PERIPHERAL QUALIFIER value of 000b (see table 47). Logi¬ 
cal unit numbers for logical units with PERIPHERAL QUALIFIER values other than 000b and 011b may be 
included in the logical unit inventory. Logical unit numbers for logical units with a PERIPHERAL QUALIFIER 
value of 011b shall not be included in the logical unit inventory. 


Table 119 — REPORT LUNS command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (AOh) 

1 

Reserved 

2 

SELECT REPORT 

3 

Reserved 

4 


5 

(MSB) ALLOCATION LENGTH 

6 

(LSB) 

7 

Reserved 

8 

CONTROL 


The SELECT REPORT field (see table 120) specifies the types of logical unit addresses that shall be reported. 


Table 120 — SELECT REPORT field 


Code 

Description 

00 h 

The list shall contain the logical units accessible to the l_T nexus with the following addressing meth¬ 
ods (see SAM-3): 

a Logical unit addressing method, 
b Peripheral device addressing method; and 
c Flat space addressing method. 


If there are no logical units, the LUN LIST LENGTH field shall be zero. 

01 h 

The list shall contain only well known logical units, if any. If there are no well known logical units, the 
LUN LIST LENGTH field shall be zero. 

02h 

The list shall contain all logical units accessible to the l_T nexus. 

03h - FFh 

Reserved 


The ALLOCATION LENGTH field is defined in 2.1.4.5. The allocation length should be at least 16. 

Note. Device servers compliant with SPC return CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB when the allo¬ 
cation length is less than 16 bytes. 

The REPORT LUNS command shall return CHECK CONDITION status only when the device server is unable 
to return the requested report of the logical unit inventory. 
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If a REPORT LUNS command is received from an l_T nexus with a pending unit attention condition (i.e., 
before the device server reports CHECK CONDITION status), the device server shall perform the REPORT 
LUNS command. If the unit attention condition was established because of a change in the logical unit inven¬ 
tory, that unit attention condition shall be cleared for the initiator port associated with that l_T nexus by the 
REPORT LUNS command. Unit attention conditions established for other reasons shall not be cleared by the 
REPORT LUNS command (see SAM-3). 

The REPORT LUNS parameter data should be returned even though the device server is not ready for other 
commands. The report of the logical unit inventory should be available without incurring any media access 
delays. If the device server is not ready with the logical unit inventory or if the inventory list is null for the 
requesting l_T nexus and the SELECT REPORT field set to 02h, then the device server shall provide a default 
logical unit inventory that contains at least LUN 0 or the REPORT LUNS well known logical unit. A non-empty 
peripheral device logical unit inventory that does not contain either LUN 0 or the REPORT LUNS well known 
logical unit is valid. 

If a REPORT LUNS command is received for a logical unit that the SCSI target device does not support and 
the device server is not capable of returning the logical unit inventory, then the command shall be terminated 
with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code 
set to LOGICAL UNIT NOT SUPPORTED. 

If the logical unit inventory changes for any reason (e.g., completion of initialization, removal of a logical unit, or 
creation of a logical unit), then the device server shall establish a unit attention condition (see SAM-3) for the 
initiator port associated with every I T nexus, with the additional sense code set to REPORTED LUNS DATA 
HAS CHANGED. 

The processing of a REPORT LUNS command that returns the logical unit inventory by any logical unit shall 
clear the REPORTED LUNS DATA HAS CHANGED unit attention condition for all logical units accessible to 
the l_T nexus on which the command was received. 

The device server shall report those devices in the logical unit inventory using the format shown in table 121. 


Table 121 — REPORT LUNS parameter data format 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

(MSB) LUN LIST LENGTH (N-7) 

3 

(LSB) 

4 

Reserved 

7 



LUN LIST 

8 

FIRST LUN 

15 




n-7 

LAST LUN 

n 
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LUN LIST LENGTH field 

The LUN LIST LENGTH field shall contain the length in bytes of the LUN list that is available to be transferred. The LUN list 
length is the number of logical unit numbers in the logical unit inventory multiplied by eight. The relationship between the 
LUN LIST LENGTH field and the CDB ALLOCATION LENGTH field is defined in Section 2.2.5. 
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3.37 REQUEST SENSE command 

The REQUEST SENSE command (see table 122) requests that the device server transfer sense data to the 
application client. 

Table 122 — REQUEST SENSE command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (03h) 

1 

Reserved DESC 

2 

Reserved 

3 


4 

ALLOCATION LENGTH 

5 

CONTROL 


DESC (Descriptor Format) bit 

The descriptor format (DESC) bit specifies which sense data format shall be returned. 

0 If DESC is set to zero, fixed format sense data shall be returned. 

1 If DESC is set to one and descriptor format sense data is supported, descriptor format sense data shall be returned. 

ALLOCATION LENGHT field 

The ALLOCATION LENGTH field is defined in 2.1.4.5. Application clients should request 252 bytes of sense data to ensure 
they retrieve all the sense data. If fewer than 252 bytes are requested, sense data may be lost since the REQUEST SENSE 
command with any allocation length clears the sense data. 

CONTROL field 

The CONTRO field is described in clause 2.2.7. 

Sense data shall be available and cleared under the conditions defined in SAM-3. If the device server has no 
other sense data available to return, it shall return the sense key set to NO SENSE and the additional sense 
code set to NO ADDITIONAL SENSE INFORMATION. 

If the logical unit is in a power condition other than the active power condition when a REQUEST SENSE com¬ 
mand is received and there is no ACA condition, it shall return the sense key set to NO SENSE and the addi¬ 
tional sense code set to one of the following: 

(a) LOW POWER CONDITION ON if the reason for entry into the power condition is unknown; 

(b) IDLE CONDITION ACTIVATED BY TIMER if the logical unit entered the idle power condition due to 
the idle condition timer; 

(c) STANDBY CONDITION ACTIVATED BY TIMER if the logical unit entered the standby power condition 
due to the standby condition timer; 

(d) IDLE CONDITION ACTIVATED BY COMMAND if the logical unit entered the idle power condition due 
to receipt of a command requiring the idle power condition while it was in the standby power condition; 
or 

(e) Another additional sense code based on requirements specified in a command standard. 

On completion of the command the logical unit shall return to the same power condition that was active before 
the REQUEST SENSE command was received. A REQUEST SENSE command shall not reset any power 
condition timers. 
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The device server shall return CHECK CONDITION status for a REQUEST SENSE command only to report 
exception conditions specific to the REQUEST SENSE command itself. 

Examples of conditions that cause a REQUEST SENSE command to return a CHECK CONDITION status are: 

(a) An invalid field value is detected in the CDB; 

(b) The device server does not support the REQUEST SENSE command (see 3.37); 

(c) An unrecovered error is detected by the service delivery subsystem; or 

(d) A malfunction prevents return of the sense data. 

If a REQUEST SENSE command is received on an l_T nexus with a pending unit attention condition (i.e., 
before the device server reports CHECK CONDITION status) and there is an exception condition specific to 
the REQUEST SENSE command itself, then the device server shall not clear the pending unit attention condi¬ 
tion (see SAM-3). 

If a recovered error occurs during the processing of the REQUEST SENSE command, the device server shall 
return the sense data with GOOD status. If a device server returns CHECK CONDITION status for a 
REQUEST SENSE command, all sense data may be invalid. 

In response to a REQUEST SENSE command issued to a logical unit that reports a peripheral qualifier of 011b 
in its standard INQUIRY data (see 3.6.2) the device server shall return GOOD status and parameter data that 
contains sense data. The sense key shall be set to ILLEGAL REQUEST and the additional sense code shall be 
set to LOGICAL UNIT NOT SUPPORTED. 

In response to a REQUEST SENSE command issued to a logical unit that reports a peripheral qualifier of 001 b 
in its standard INQUIRY data, the device server shall return GOOD status and parameter data that contains 
sense data. The sense key shall be set to ILLEGAL REQUEST and the additional sense code shall be set to 
LOGICAL UNIT NOT SUPPORTED. 

In response to a REQUEST SENSE command issued to a logical unit that reports a peripheral qualifier of 000b 
in its standard INQUIRY data because it has a peripheral device connected but is not ready for access, the 
device server shall return GOOD status and parameter data that contains sense data appropriate to the condi¬ 
tion that is making the logical unit not operational. 

In response to a REQUEST SENSE command issued to a logical unit that reports a peripheral qualifier of 000b 
in its standard INQUIRY data because the device server is unable to determine whether or not a peripheral 
device is connected, the device server shall return GOOD status and parameter data that contains sense data 
with the sense key set to NO SENSE. 

Device servers shall return at least 18 bytes of parameter data in response to a REQUEST SENSE command 
if the allocation length is 18 or greater and the DESC bit is set to zero. Application clients may determine how 
much sense data has been returned by examining the ALLOCATION LENGTH field in the CDB and the ADDI¬ 
TIONAL SENSE LENGTH field in the sense data. Device servers shall not adjust the additional sense length to 
reflect truncation if the allocation length is less than the sense data available. 

Targets shall be capable of returning eighteen bytes of data in response to a REQUEST SENSE command. If 
the ALLOCATION LENGTH is 18 or greater, and a target returns less than 18 bytes of data, the initiator should 
assume that the bytes not transferred would have been zeros had the target returned those bytes, initiators 
may determine how much sense data has been returned by examining the ALLOCATION LENGTH field in the 
command descriptor block and the Additional Sense Length field in the sense data, targets shall not adjust the 
additional sense length to reflect truncation if the ALLOCATION LENGTH is less than the sense data available. 
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The sense data format for response codes 70h (current errors) and 71 h (deferred errors) are defined in Table 
123. 


Table 123 — Response codes 70h and 71 h sense data format 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

VALID [1] 

RESPONSE CODE (70h or 71 h) [2] 

1 

Obsolete [3] 

2 

FILEMARK 

[4] 

EOM [5] 

ILI [6] 

Reserved 

SENSE KEY [7] 

3 

(MSB) 



INFORMATION [8] 




6 








(LSB) 

7 

ADDITIONAL SENSE LENGTH (n - 7) [9] 

8 

(MSB) 


COMMAND-SPECIFIC INFORMATION [10] 



11 








(LSB) 

12 

ADDITIONAL SENSE CODE [11] 

13 

ADDITIONAL SENSE CODE QUALIFIER [12] 

14 

FIELD REPLACEABLE UNIT CODE [13] 

15 

SKSV [14] 


SENSE KEY SPECIFIC [15] 



17 









18 



ADDITIONAL SENSE BYTES [16] 



n 










[1] A VALID bit of zero indicates that the INFORMATION field is not as defined in this manual. A VALID bit of 
one indicates the INFORMATION field contains valid information as defined in this manual, targets shall 
implement the VALID bit. 

[2] RESPONSE CODE value 70h (current errors) is described in Section 2.4.1.3. targets shall implement 
RESPONSE CODE 70h. RESPONSE CODE 71 h (deferred errors) is described in Section 2.4.1.6. Imple¬ 
mentation of RESPONSE CODE 71 h is optional. RESPONSE CODE 7Fh is for a vendor-specific sense 
data formats. RESPONSE CODE values 72h to 7Eh and OOh to 6Fh are reserved. 

[3] Obsolete. Seagate disc drives do not currently implement any of the COPY commands. 

The SEGMENT NUMBER field contains the number of the current segment descriptor if the REQUEST 
SENSE command is in response to a COPY, COMPARE, or COPY AND VERIFY command. Up to 256 
segments are supported, beginning with segment zero. 

[4] The Filemark bit is mandatory for sequential-access devices, and this bit is reserved for all other device 
types. A Filemark bit of one indicates that the current command has read a filemark or setmark. The Addi¬ 
tional Sense Code field may be used to indicate whether a filemark or setmark was read. Reporting of set- 
marks is optional and indicated by the RSMK bit for sequential-access devices in the configuration 
parameters page. (See SSC.) 

[5] The End-of-Medium (EOM) bit is mandatory for sequential-access and printer devices, and this bit is 
reserved for all other device types. An EOM bit of one indicates that an end-of-medium condition (end-of- 
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partition, beginning-of-partition, out-of-paper, etc.) exists. For sequential-access devices, this bit indicates 
that the unit is at or past the early-warning if the direction was forward, or that the command was not com¬ 
pleted because beginning-of-partition was encountered if the direction was reverse. (See SSC.) 

[6] An Incorrect Length Indicator (ILI) bit of one usually indicates that the requested logical block length did 
not match the logical block length of the data on the medium. 

[7] The SENSE KEY, ADDITIONAL SENSE CODE and ADDITIONAL SENSE CODE QUALIFIER fields pro¬ 
vide a hierarchy of information. The intention of the hierarchy is to provide a top-down approach for an ini¬ 
tiator to determine information relating to the error and exception conditions. The sense key provides 
generic categories in which error and exception conditions may be reported, initiators typically use sense 
keys for high level error recovery procedures. 

Additional sense codes provide further detail describing the sense key. Additional sense code qualifiers 
add further detail to the additional sense code. The additional sense code and additional sense code qual¬ 
ifier may be used by initiators where sophisticated error recovery procedures require detailed information 
describing the error and exception conditions. 

The Sense Key field is mandatory and indicates generic information describing an error or exception con¬ 
dition. The sense keys are defined in Section 2.4.1.5. 

[8] The contents of the INFORMATION field is device-type or command specific and is defined within the 
appropriate standard for the device type or command of interest, targets shall implement the INFORMA¬ 
TION field. Unless specified otherwise, this field contains: 

a. the unsigned LOGICAL BLOCK ADDRESS associated with the sense key, for direct-access devices 
(device type 0), write-once devices (device type 4), CD-ROM devices (device type 5), and optical 
memory devices (device type 7); 

b. the difference (residue) of the requested length minus the actual length in either bytes or blocks, as 
deter-mined by the command, for sequential-access devices (device type 1), printer devices (device 
type 2), processor devices (device type 3) and some direct access device commands, except as 
defined for d) below. Negative values are indicated by two's complement notation; 

c. the difference (residue) of the requested number of blocks minus the actual number of blocks copied 
or compared for the current segment descriptor of a COPY, COMPARE, COPY AND VERIFY, or 
Extended COPY command; or 

d. for sequential-access devices operating in buffered modes 1 h or 2h that detect an unrecoverable write 
error when unwritten data blocks, filemarks, or setmarks remain in the buffer, the value of the informa¬ 
tion field for all commands shall be: 

• the total number of data blocks, filemarks, and setmarks in the buffer if the 
device is in fixed block mode (block length field of the MODE SENSE block descriptor is non-zero and the 
fixed bit of the WRITE command is one); or 

• the number of bytes in the buffer, including filemarks and setmarks, if the 
device is in variable mode (the fixed bit of the WRITE command is zero). 

For additional information, see SSC (SCSI Stream Device Command Set, T10/997D). 

[9] The ADDITIONAL SENSE LENGTH field indicates the number of additional sense bytes to follow. If the 
ALLOCATION LENGTH of the command descriptor block is too small to transfer all of the additional sense 
bytes, the additional sense length is not adjusted to reflect the truncation. 

[10] The COMMAND-SPECIFIC INFORMATION field contains information that depends on the command that 
was executed. Further meaning for this field is defined within the command description. The COMMAND- 
SPECIFIC INFORMATION field is mandatory if the target supports any of the following commands: COPY, 
COMPARE, COPY AND VERIFY, Extended COPY and REASSIGN BLOCKS. 

[11] The Additional Sense Code (ASC) indicates further information related to the error or exception condition 
reported in the sense key field, targets shall support the ASC field. Support of the additional sense codes 
not explicitly required by this manual is optional. A list of additional sense codes is in Section 2.4.1.6. If the 
target does not have further information related to the error or exception condition, the additional sense 
code is set to No Additional Sense Information. 
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[12] The Additional Sense Code Qualifier (ASCQ) indicates detailed information related to the additional sense 
code. The additional sense code qualifier is optional. If the error or exception condition is reportable by the 
device, the value returned shall be as specified in Section 2.4.1.6. If the target does not have detailed 
information related to the error or exception condition, the additional sense code qualifier is set to zero. 

[13] Non-zero values in the FIELF REPLACEABLE UNIT CODE field are used to define a device-specific 
mechanism or unit that has failed. A value of zero in this field shall indicate that no specific mechanism or 
unit has been identified to have failed or that the data is not available. The FIELD REPLACEABLE UNIT 
CODE field is optional. The format of this information is not specified by this manual. Additional informa¬ 
tion about the field replaceable unit may be available in the ASCII information page (see Section 4.4.2), if 
supported by the target. 

[14] The SENSE KEY SPECIFIC bytes are described in Section 3.37.1. 

[15] The ADDITIONAL SENSE BYTES field may contain command specific data, peripheral device specific 
data, or vendor-specific data that further defines the nature of the CHECK CONDITION status. 

[16] Bytes 18-n are not presently used. 

3.37.1 Sense Key Specific field 

The SENSE KEY SPECIFIC field as defined by this manual when the value of the Sense Key Specific Valid 

(SKSV) bit is one. The SKSV bit and SENSE KEY SPECIFIC fields are optional. The definition of this field is 

determined by the value of the SENSE KEY field. This field is reserved for sense keys not described below. An 

SKSV value of zero indicates that this field is not as defined by this manual. 


Table 124 — Field pointer bytes 


Bits 

Bytes 

7 

6 

5 4 

3 

2 1 0 

15 

SKSV [1] 

C/D [2] 

Reserved 

BPV [3] 

BIT POINTER [4] 

16 

(MSB) 

FIELD POINTER [5] 


17 


(LSB) 


[1] SKSV. If the sense key is ILLEGAL REQUEST and the SKSV bit is set to one, the SENSE KEY SPECIFIC 
field (Table 123) shall be as defined as shown in this table. The FIELD POINTER field indicates which ille¬ 
gal parameters in the command descriptor block or the data parameters are in error. 

[2] A Command Data (C/D) bit of one indicates that the illegal parameter is in the command descriptor block. 
A C/D bit of zero indicates that the illegal parameter is in the data parameters sent by the initiator in the 
Data Out Buffer. 

[3] A Bit Pointer Valid (BPV) bit of zero indicates that the value in the Bit Pointer field [4] is not valid. A BPV bit 
of one indicates that the BIT POINTER field specifies which bit of the byte designated by the FIELD 
POINTER field is in error. 

[4] When a multiple-bit field is in error, the BIT POINTER field shall point to the most-significant (left-most) bit 
of the field. 

[5] The FIELD POINTER field indicates which byte of the command descriptor block or of the parameter data 
was in error. Bytes are numbered starting from zero, as shown in the tables describing the commands and 
parameters. 

When a multiple-byte field is in error, the field pointer shall point to the most significant (left-most) byte of 
the field. If several consecutive bytes are reserved, each shall be treated as a single-byte field. 

Note. Bytes identified as being in error are not necessarily the place that has to be changed to correct 
the problem. 
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If the sense key is RECOVERED ERROR (1 h), HARDWARE ERROR (4h), or MEDIUM ERROR (3h), and if 
the SKSV bit is one, the SENSE KEY SPECIFIC field is defined as shown in Table 125. These fields identify 
the actual number of retries used in attempting to recover from the error condition. 

Table 125 — Actual Retry Count Bytes 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

15 

SKSV 

Reserved 

16 

(MSB) 


ACTUAL RETRY COUNT [1] 



17 








(LSB) 


[1] The ACTUAL RETRY COUNT field returns implementation specific information on the actual number of 
retries used in attempting to recover an error or exception condition. 

Not all drives implement reporting actual retry count in bytes 15,16, and 17. See individual drive’s Product 
Manual, Volume 1. 

Note. This field relates to the retry count fields specified within the error recovery parameters page of the 
MODE SELECT command (see Table 58). 

If the sense key is NOT READY and the SKSV bit is one, the SENSE KEY SPECIFIC field shall be defined as 
shown in Table 124. These fields are only defined for the FORMAT UNIT command with the IMMED bit set to 
one. 

Table 126 — Progress Indication Bytes 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

15 

SKSV 

Reserved 

16 

(MSB) 


PROGRESS INDICATION [1] 



17 








(LSB) 


[1] The PROGRESS INDICATION field is a percent complete indication in which the returned value is the 
numerator that has 65536 (lOOOOh) as its denominator. The progress indication shall be based upon the 
total operation. 

Support or non-support for the Progress Indication field is given in individual drive’s Product Manual, Vol¬ 
ume 1, SCSI bus conditions and miscellaneous features supported section. 

Note. It is intended that the progress indication be time related. However, since, for example, format time 
varies with the number of defects encountered, etc., it is reasonable for the target to assign values 
to various steps within the process. The granularity of these steps should be small enough to pro¬ 
vide reasonable assurances to the initiator that progress is being made. 


Table 127 — Segment pointer bytes 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

15 

SKSV [1] 

Reserved 

SD [2] 

Reserved 

BPV [3] 

BIT POINTER [4] 
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Table 127 — Segment pointer bytes 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

16 

(MSB) 



FIELD POINTER [5] 



17 







(LSB) 


[1] SKSV described previously in Table 124. 

[2] The Segment Descriptor (SD) bit indicates whether the field pointer is with reference to the start of the 
parameter list or to the start of a segment descriptor. An SD value of zero indicates that the field pointer is 
relative to the start of the parameter list. An SD value of one indicates that the field pointer is relative to 
the start of the segment descriptor indicated by the third and fourth bytes of the Command-Specific Infor¬ 
mation field of the Extended COPY command, which devices addressed by this manual do not imple¬ 
mented. 

[3] A Bit Pointer Valid (BPV) bit of zero indicates that the value in the Bit Pointer field is not valid. A BPV bit of 
one indicates that the Bit Pointer field specifies which bit of the byte designated by the Field Pointer field 
is in error. 

[4] When a multiple-bit field is in error, the BIT POINTER field shall point to the most-significant (left-most) bit 
of the field. 

[5] The FIELD POINTER field indicates which byte of the parameter list or segment descriptor was in error. 

Note. If the parameter list is in excess of 65528 bytes in length and SD is 0, the FIELD POINTER value 
may not fit in two bytes provided by the sense key specific format definition. 
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3.38 


RESERVE(6) command 


This command has been declared obsolete by the T10 committee. However, it is included because it 
may be implemented on some products. 


The RESERVE(6) command (see table 128) is used to reserve a logical unit. This subclause describes only 
those instances where the RESERVE(6) command differs from the RESERVE(IO) command. Except for the 
instances described in this subclause, the RESERVE(6) command shall function exactly like the 
RESERVED 0) command (see 3.40). 


Table 128 — RESERVE(6) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (16h) 

1 

Reserved Obsolete 

2 

Obsolete 

3 


4 

Obsolete 

5 

CONTROL 


Obsolete Bits 1 through 4 of Byte 1 provided a method, limited to device addresses 0 through 7, to handle 
third-party reservations in earlier versions of the SCSI standard. The obsolete method has been replaced by 
the RESERVED 0) and RELEASE(IO). 

Byte 1 Bit 0 and Bytes 2 through 4 provide an obsolete way to reserve extents within a logical unit. If Byte 1, Bit 
0 is equal to one, device servers not implementing the obsolete capability shall terminate the command with 
CHECK CONDITION status and the sense key shall be set to ILLEGAL REQUEST. 
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3.39 


RESERVE (10) command 


This command has been declared obsolete by the T10 committee. However, it is included because it 
may be implemented on some products. 


3.39.1 RESERVE (10) command introduction 

The RESERVE(IO) command (see table 129) is used to reserve a logical unit. 

Table 129 — RELEASE (10) Command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (56h) 

1 

Reserved 3RDPTY Reserved LONGID Obsolete 

2 

Obsolete 

3 

THIRD-PARTY DEVICE ID 

4 

Reserved 

5 

Reserved 

6 

Reserved 

7 

(MSB) PARAMETER LIST LENGTH 

8 

(LSB) 

9 

CONTROL 


The RESERVE and RELEASE commands provide a basic mechanism for contention resolution in multiple-ini¬ 
tiator systems. The third-party reservation allows logical units to be reserved for another specified SCSI 
device. See 5.5.1 for a general description of reservations and the commands that manage them. 

If the RESERVE(10) command is implemented, then the RELEASE(10) also shall be implemented. 

Byte 1 Bit 0 and Byte 2 provide an obsolete way to reserve extents within a logical unit. If Byte 1, Bit 0 is equal 
to one, device servers not implementing the obsolete capability shall terminate the command with CHECK 
CONDITION status and the sense key shall be set to ILLEGAL REQUEST. 

3.39.2 Logical unit reservation 

Logical unit reservations are mandatory if the RESERVE(IO) command is implemented. This command shall 
request that the entire logical unit be reserved for the exclusive use of the initiator until the reservation is super¬ 
seded by another valid RESERVE command from the same initiator or until released by a RELEASE command 
from the same initiator that made the reservation, by a TARGET RESET task management function performed 
by any initiator, by a hard reset condition, or by a power on cycle. A logical unit reservation shall not be granted 
if the logical unit is reserved by another initiator. It shall be permissible for an initiator to reserve a logical unit 
that is currently reserved by that initiator. If the LONGID bit or the 3rdPty bit is zero then the PARAMETER 
LIST LENGTH field shall be ignored. 

If the logical unit is reserved for another initiator, the device server shall return RESERVATION CONFLICT sta¬ 
tus. After honoring a logical unit reservation, the device server shall check each newly received command for 
reservation conflicts. 

For multiple port implementations, devices on other ports (i.e., the ports that do not include the initiator to which 
the reservation has been granted) also shall be denied access to the logical unit as described in the preceding 
clause. 
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3.39.3 


Third-party reservation 


Third-party reservations are mandatory if the RESERVE(IO) command is implemented. The third-party reser¬ 
vation for the RESERVE(IO) command allows an application client to reserve a logical unit within a logical unit 
for another SCSI device. This is intended for use in multiple initiator systems that use the COPY or 
EXTENDED COPY command. 

If the third-party (3RDPTY) bit is zero, then a third-party reservation is not requested. If the 3RDPTY bit is zero 
then the LONGID bit shall be ignored. If the 3RDPTY bit is one then the device server shall reserve the speci¬ 
fied logical unit for the SCSI device specified in the THIRD-PARTY DEVICE ID field. Device ID formats are pro¬ 
tocol specific. The device server shall preserve the reservation until it is superseded by another valid 
RESERVE command from the initiator that made the reservation or until it is released by the same initiator, by 
a TARGET RESET task management function performed by any initiator, a hard reset condition, or by a power 
on cycle. The device server shall ignore any attempt to release the reservation made by any other initiator. 

After a third-party reservation has been granted, the initiator that sent the RESERVE command shall be treated 
like any other initiator. Reservation conflicts shall occur in all cases where another initiator is not allowed 
access due to the reservation. 

If independent sets of mode parameters are implemented, a third-party reservation shall cause the device 
server to transfer the set of mode parameters in effect for the application client that sent the RESERVE com¬ 
mand to the mode parameters used for commands from the third-party device. Any subsequent command 
issued by the third-party device shall be executed according to the mode parameters in effect for the applica¬ 
tion client that sent the RESERVE command. 

Note. This transfer of the mode parameters is applicable to device servers that store mode information 
independently for different initiators. This mechanism allows an application client to set the mode 
parameters of a target for the use of a copy master (i.e., the third-party device). The third-party 
copy master may subsequently issue a MODE SELECT command to modify the mode parameters. 

If the THIRD-PARTY DEVICE ID value associated with the reservation release is smaller than 255, the 
LONGID bit may be zero and the ID value sent in the CDB. Device ID formats are protocol specific. If the 
THIRD-PARTY DEVICE ID is greater than 255, the LONGID bit shall be one. If the LONGID bit is one, the 
THIRD-PARTY DEVICE ID field in the CDB shall be ignored. If the LONGID bit is one, the parameter list length 
shall be at least eight. If the LONGID bit is one and the parameter list length is less than eight, the device 
server shall return a CHECK CONDITION status with a sense key of ILLEGAL REQUEST. 

Device servers that support device IDs greater than 255 shall accept commands with LONGID equal to one. 
Device servers whose devices IDs are limited to 255 or smaller may reject commands with LONGID equal to 
one with CHECK CONDITION status and a sense key of ILLEGAL REQUEST. 

If the LONGID bit is one, the parameter list length shall be eight, and the parameter list shall have the format 
shown in table 107. If the LONGID bit is one and the parameter list length is not eight, the device server shall 
return a CHECK CONDITION status with a sense key of ILLEGAL REQUEST. 


Table 130 — RESERVE(IO) ID only parameter list 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 








7 



THIRD-PARTY EDEVICE ID 




3.39.4 Superseding reservations 

Superseding reservations is mandatory if the RELEASE(IO) command is implemented. An application client 
that holds a current logical unit reservation may modify that reservation by issuing another RESERVE com¬ 
mand to the same logical unit. The superseding RESERVE command shall release the previous reservation 
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state when the new reservation request is granted. The current reservation shall not be modified if the super¬ 
seding reservation request is not granted. If the superseding reservation cannot be granted because of con¬ 
flicts with a previous reservation, other than the reservation being superseded, then the device server shall 
return RESERVATION CONFLICT status. 

Note. Superseding reservations allow the SCSI device ID in a third-party reservation to be changed. This 
capability is necessary for certain situations when using the EXTENDED COPY command. 
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3.40 REZERO UNIT command 

This command has been declared obsolete by the T10 committee. However, it is included because it 
may be implemented on some products. 

Table 131 — REZERO UNIT command (01 h) 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (01 h) 

1 

LUN [1] 

2 

LOGICAL BLOCK ADDRESS MUST BE 0’S 

3 

4 

Reserved 

5 

CONTROL [2] 


The Rezero Unit command (Table 108) requests that the disc drive set its logical block address to zero and 
return the disc drive read/write heads to the track (or cylinder) containing Logical Block Zero. This command is 
intended for systems which disable retries and the initiator performs error recovery. It is longer than a seek to 
Logical Block Address zero and should be utilized if seek errors are encountered. 

For systems that support disconnection, the disc drive disconnects when this command is received. 

A Rezero Command also causes a thermal compensation to occur and resets the thermal compensation cycle 
timer back to its start, thus allowing the host to know when to expect the next thermal compensation to occur. 
The host can thus prevent critical data transfer operations from being interrupted at an undesirable time. 

For drives that support saved log parameters, the Rezero Unit command will also save log counters to the 
media and reset the log save timer back to its start. 

Note. 

[1] The LUN must be zero. 

[2] See “Control Byte” clause 2.1.4.6. 
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3.41 SEEK command 

This command has been declared obsolete by the T10 committee. However, it is included because it 
may be implemented on some products. 

Table 132 — SEEK command (OBh) 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (Obh) 

1 

LUN [1] MSB 

2 

LOGICAL BLOCK ADDRESS [2] 

3 

LSB 

4 

Reserved 

5 

CONTROL [3] 


The Seek command (Table 109) requests that the disc drive seek to the specified logical block address. 

For systems which support disconnection, the disc drive disconnects when a valid Seek command is received. 
The use of this command is infrequent since all commands involving data transfer to/from the disc drive media 
contain implied seek addresses. 

Note. 

[1] The Logical Unit number should be zero. 

[2] The maximum Logical Block Address that may be specified for a Seek command is defined in Read 
Capacity Data. 

[3] See “Control Byte” clause 4.2.6. 
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3.42 SEEK EXTENDED command 

This command has been declared obsolete by the T10 committee. However, it is included because it 
may be implemented on some products. 

Table 133 — SEEK command (2Bh) 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (Obh) 

1 

LUN [1] Reserved 

2 

LOGICAL BLOCK ADDRESS (MSB) 

3 

LOGICAL BLOCK ADDRESS LSB 

4 

LOGICAL BLOCK ADDRESS 

5 

LOGICAL BLOCK ADDRESS (LSB) [2] 

6 

Reserved 

7 

Reserved 

8 

Reserved 

9 

CONTROL [3] 


The Seek Extended command (Table 110) requests that the disc drive seek to the specified logical block 
address. 

This command is implemented with the disc drive specific parameters listed in Table 3. 

LUN (Logical Unit Number) field 

Seagate drives only support Logical Unit Number 0. 

Note. Byte 1 should be OOh. 

LOGICAL BLOCK ADDRESS field 

Four byte Logical Address may be specified. The drive will seek to this address when the command is 
received. 

Note. 

[1] In the CDB, the LUN must be zero. 

[2] The maximum Logical Block Address that may be specified for a Seek command is defined in Read Capac¬ 
ity Data. 

[3] See “Control Byte” clause 4.2.6. 
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3.43 


SEND DIAGNOSTIC command 


The SEND DIAGNOSTIC command (see table 134) requests the device server to perform diagnostic opera¬ 
tions on the SCSI target device, on the logical unit, or on both. Logical units that support this command shall 
implement, at a minimum, the default self-test feature (i.e., the SELFTEST bit equal to one and a parameter list 
length of zero). 


Table 134 — SEND DIAGNOSTIC command 


Bit 

Byte 

7 6 5 4 3 2 1 0 


OPERATION CODE (IDh) 


SELF-TEST CODE PF Reserved SELFTEST DEVOFFL UNITOFFL 


Reserved 


(MSB) PARAMETER LIST LENGTH 


(LSB) 


CONTROL 


SELFTEST bit 

1 If the SELFTEST bit is set to one, the SELF-TEST CODE field shall contain 000b. 

0 If the SELFTEST bit is set to zero, the contents of SELF-TEST CODE field are specified in table 135. 
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Table 135 — SELF-TEST CODE field 


Code 

Name 

Description 

000b 


This value shall be used when the SELFTEST bit is set to one, or when the SELFT¬ 
EST bit is set to zero and the PF bit is set to one. 

001b 

Background 

short self-test 

The device server shall start its short self-test (see SPC-4 clause 5.5.2) in the back¬ 
ground mode (see SPC-4 clause 5.5.3.3). The PARAMETER LIST LENGTH field 
shall contain zero. 

010b 

Background 
extended self-test 

The device server shall start its extended self-test (see SPC-4 clause 5.5.2) in the 
background mode (see SPC-4 clause 5.6.3.3). The PARAMETER LIST LENGTH 
field shall contain zero. 

011b 

Reserved 

100b 

Abort background 
self-test 

The device server shall abort the current self-test running in background mode. The 
PARAMETER LIST LENGTH field shall contain zero. This value is only valid if a pre¬ 
vious SEND DIAGNOSTIC command specified a background self-test function and 
that self-test has not completed. If either of these conditions is not met, the command 
shall be terminated with CHECK CONDITION status, with the sense key set to ILLE¬ 
GAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 

101b 

Foreground 

short self-test 

The device server shall start its short self-test (see SPC-4 clause 5.5.2) in the fore¬ 
ground mode (see SPC-4 clause 5.5.3.2). The PARAMETER LIST LENGTH field 
shall contain zero. 

110b 

Foreground 
extended self-test 

The device server shall start its extended self-test (see SPC-4 clause 5.5.2) in the 
foreground mode (see SPC-4 clause 5.5.3.2). The PARAMETER LIST LENGTH field 
shall contain zero. 

111b 

Reserved 


PF (page format) bit 

1 A page format (PF) bit set to one specifies that the SEND DIAGNOSTIC parameters and any parameters returned 
by a following RECEIVE DIAGNOSTIC RESULTS command with the PCV bit set to zero shall contain a single diag¬ 
nostic page as defined in 4.1.1. 

Note. Logical units compliant with previous versions of SPC-4 may transfer more than one diagnostic 
page in the SEND DIAGNOSTIC command’s parameter list and by doing so may request that more 
than one diagnostic page be transmitted in the RECEIVE DIAGNOSTIC RESULTS command’s 
parameter data. 

0 A PF bit set to zero specifies that all SEND DIAGNOSTIC parameters are vendor specific. If the PARAMETER LIST 
LENGTH field is set to zero and the SEND DIAGNOSTIC command is not going to be followed by a corresponding 
RECEIVE DIAGNOSTIC RESULTS command with the PCV bit set to zero, then the application client shall set the 
PF bit to zero. The implementation of the PF bit is optional. 

SELFTEST (Self-test) bit 

1 A self-test (SELFTEST) bit set to one specifies that the device server shall perform the logical unit default self-test. 
If the self-test successfully passes, the command shall be terminated with GOOD status. If the self-test fails, the 
command shall be terminated with CHECK CONDITION status, with the sense key set to HARDWARE ERROR. 

0 A SELFTEST bit set to zero specifies that the device server shall perform the diagnostic operation specified by the 
SELF-TEST CODE field or in the parameter list. The diagnostic operation may require the device server to return 
parameter data that contains diagnostic results. If the return of parameter data is not required, the return of GOOD 
status indicates successful completion of the diagnostic operation. If the return of parameter data is required, the 
device server shall either: 
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[a] Perform the requested diagnostic operation, prepare the parameter data to be returned and indicate 
completion by returning GOOD status. The application client issues a RECEIVE DIAGNOSTIC 
RESULTS command to recover the parameter data; or 

[b] Accept the parameter list, and if no errors are detected in the parameter list, return GOOD status. The 
requested diagnostic operation and the preparation of the parameter data to be returned are per¬ 
formed upon receipt of a RECEIVE DIAGNOSTIC RESULTS command. 

UNITOFFL (unit offline) bit 

1 A unit offline (UNITOFFL) bit set to one specifies that the device server may perform diagnostic operations that may 
affect the user accessible medium on the logical unit (e.g., write operations to the user accessible medium, or repo¬ 
sitioning of the medium on sequential access devices). The device server may ignore the UNITOFFL bit. 

0 A UNITOFFL bit set to zero prohibits any diagnostic operations that may be detected by subsequent tasks. When 
the SELFTEST bit is set to zero, the UNITOFFL bit shall be ignored. 

DEVOFFL (SCSI target device offline) bit 

1 A SCSI target device offline (DEVOFFL) bit set to one grants permission to the device server to perform diagnostic 
operations that may affect all the logical units in the SCSI target device (e.g., alteration of reservations, log parame¬ 
ters, or sense data). The device server may ignore the DEVOFFL bit. 

0 A DEVOFFL bit set to zero prohibits diagnostic operations that may be detected by subsequent tasks. When the 
SELFTEST bit is set to zero, the DEVOFFL bit shall be ignored. 

PARAMETER LIST LENGTH field 

The PARAMETER LIST LENGTH field specifies the length in bytes of the parameter list that shall be trans¬ 
ferred from the application client Data-Out Buffer to the device server. A parameter list length of zero specifies 
that no data shall be transferred. This condition shall not be considered an error. If PF bit is set to one and the 
specified parameter list length results in the truncation of the diagnostic page (e.g., the parameter list length 
does not match the page length specified in the diagnostic page), then the command shall be terminated with 
CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set 
to INVALID FIELD IN CDB. 

To ensure that the diagnostic command information is not destroyed by a command sent from another l_T 
nexus, the logical unit should be reserved. 
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3.44 


SET DEVICE IDENTIFIER command 


The SET DEVICE IDENTIFIER command (see table 136) requests that the device identifier information in the 
logical unit be set to the value received in the SET DEVICE IDENTIFIER parameter list. As defined in the SCC- 
2 standard, the SET DEVICE IDENTIFIER command is the SET PERIPHERAL DEVICE/COMPONENT 
DEVICE IDENTIFIER service action of the MAINTENANCE OUT command. Additional MAINTENANCE IN 
and MAINTENANCE OUT service actions are defined in SCC-2 and in this standard. 

The MAINTENANCE OUT service actions defined only in SCC-2 shall apply only to SCSI devices that return a 
device type of OCh or the SCCS bit set to one in their standard INQUIRY data. When a SCSI devices returns a 
device type of OCh or the SCCS bit set to one in its standard INQUIRY data, the implementation requirements 
for the SCC-2 MAINTENANCE OUT service actions shall be as specified in SCC-2. Otherwise the MAINTE¬ 
NANCE OUT service action definitions and implementation requirements stated in this standard shall apply. 

On successful completion of a SET DEVICE IDENTIFIER command that changes the device identifier saved 
by the logical unit, the device server shall establish a unit attention condition (see SAM-3) for the initiator port 
associated with every l_T nexus except the l_T nexus on which the SET IDENTIFIER command was received, 
with the additional sense code set to DEVICE IDENTIFIER CHANGED. 


Table 136 — SET DEVICE IDENTIFIER command 


Bit 

Byte 

7 6 5 4 3 2 

1 

0 

0 

OPERATION CODE (A4h) 

1 

Reserved SERVICE ACTION (06h) 

2 

Reserved 



3 



4 

RESTRICTED 



5 



6 

(MSB) PARAMETER LIST LENGTH 



7 


(LSB) 

8 

Reserved 

RESTRICTE 

D 

Reserved 

9 

CONTROL 


SCC-2 defines specific usages for bytes 4 and 5, and bit 1 in byte 10, however these fields are reserved for the 
SET DEVICE IDENTIFIER command defined by this standard. 

The PARAMETER LIST LENGTH field specifies the length in bytes of the identifier that shall be transferred 
from the application client to the device server. The maximum value for this field shall be 512 bytes. A parame¬ 
ter list length of zero specifies that no data shall be transferred, and that subsequent REPORT DEVICE IDEN¬ 
TIFIER commands shall return an Identifier length of zero. Logical units that implement this command shall be 
capable of accepting a parameter list length of 64 bytes or less. If the parameter list length exceeds 64 bytes 
and the logical unit is not capable of storing the requested number of bytes, then the command shall be termi¬ 
nated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional 
sense code set to INVALID FIELD IN CDB. 
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The SET DEVICE IDENTIFIER parameter list (see table 137) contains the identifier to be set by the addressed 
logical unit. 

Table 137 — SET DEVICE IDENTIFIER parameter list 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 




IDENTIFIER 



n 









The IDENTIFIER field is a value selected by the application client using mechanisms outside the scope of this 
standard to be returned in subsequent REPORT DEVICE IDENTIFIER commands. 


SCSI Commands Reference Manual, Rev. A 


169 




3.45 


START STOP UNIT command 


The START STOP UNIT command (see table 138) requests that the device server change the power condition 
of the logical unit or load or eject the medium. This includes specifying that the device server enable or disable 
the direct-access block device for medium access operations by controlling power conditions and timers. 

Logical units that contain cache shall write all cached logical blocks to the medium (e.g., as they would do in 
response to a SYNCHRONIZE CACHE command (see 3.46 and 3.47) with the SYNC_NV bit set to zero, the 
LOGICAL BLOCK ADDRESS field set to zero, and the NUMBER OF BLOCKS field set to zero) prior to enter¬ 
ing into any power condition that prevents accessing the medium (e.g., before the rotating media spindle motor 
is stopped during transition to the stopped power condition). 


Table 138 — START STOP UNIT command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (1 Bh) 

1 

Reserved IMMED 

2 

Reserved 

3 


4 

POWER CONDITION Reserved LOEJ START 

5 

CONTROL 


IMMED (Immediate) bit 

0 If the immediate (IMMED) bit is set to zero, then the device server shall return status after the operation is com¬ 
pleted. 

1 If the IMMED bit set to one, then the device server shall return status as soon as the CDB has been validated. 

POWER CONDITION field 

The POWER CONDITION field is used to specify that the logical unit be placed into a power condition or to adjust a timer 
as defined in table 139. If this field is supported and is set to a value other than Oh, then the START and LOEJ bits shall be 
ignored. 

Table 139 — POWER CONDITION field 


Code 

Name 

Description 

Oh 

STARTVALID 

Process the START and LOEJ bits. 

1h 

ACTIVE 

Place the device into the active power condition. 

2h 

IDLE 

Place the device into the idle power condition. 

3h 

STANDBY 

Place the device into the standby power condition. 


170 


SCSI Commands Reference Manual, Rev. A 





Table 139 — POWER CONDITION field 


Code 

Name 

Description 

4h 

Reserved 

Reserved 

5h 

Obsolete 

Obsolete 

6h 

Reserved 

Reserved 

7h 

LU_CONTROL 

Transfer control of power conditions to the logical unit. 

8h-9h 

Reserved 

Reserved 

Ah 

FORCEIDLEO 

Force the idle condition timer to zero. 

Bh 

FORCE_STANDBY_0 

Force the standby condition timer to zero. 

Ch-Fh 

Reserved 

Reserved 


If the START STOP UNIT command is received with the POWER CONDITION field set to ACTIVE, IDLE, or 
STANDBY, then: 

(a) the logical unit shall transition to the specified power condition; 

(b) the logical unit shall change power conditions only after receipt of another START STOP UNIT com¬ 
mand or a logical unit reset; 

(c) the device server shall disable the idle condition timer if it is active (see SPC-4) and disable the 
standby condition timer if it is active (see SPC-4) until another START STOP UNIT command is 
received that returns control of the power condition to the logical unit, or a logical unit reset occurs. 

If the START STOP UNIT command is received with the POWER CONDITION field set to LU_CONTROL, then 
the device server shall enable the idle condition timer if it is active (see SPC-4) and disable the standby condi¬ 
tion timer if it is active (see SPC-4). 

If the START STOP UNIT command is received with the POWER CONDITION field set to FORCE_IDLE_0 or 
FORCE_STANDBY_0, then the device server shall: 

(a) force the specified timer to zero, cause the logical unit to transition to the specified power condition, 
and return control of the power condition to the device server; or 

(b) terminate a START STOP UNIT command that selects a timer that is not supported by the device 
server or a timer that is not active. The command shall be terminated with CHECK CONDITION status 
with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN 
CDB. 

It is not an error to specify that the logical unit transition to its current power condition. 

LOEJ (load eject) bit 

0 If the load eject (LOEJ) bit is set to zero, then the logical unit shall take no action regarding loading or ejecting the 
medium. 

1 If the LOEJ bit is set to one, then the logical unit shall unload the medium if the START bit is set to zero. If the LOEJ 
bit is set to one, then the logical unit shall load the medium if the START bit is set to one. 

START bit 

0 If the START bit is set to zero, then the logical unit shall transition to the stopped power condition, disable the idle 
condition timer if it is active (see SPC-4), and disable the standby condition timer if it is active (see SPC-4). 

1 If the START bit set to one, then the logical unit shall transition to the active power condition, enable the idle condi¬ 
tion timer if it is active, and enable the standby condition timer if it is active. 
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3.46 


SYNCHRONIZE CACHE (10) command 


The SYNCHRONIZE CACHE (10) command (see table 140) requests that the device server ensure that the 
specified logical blocks have their most recent data values recorded in non-volatile cache and/or on the 
medium, based on the SYNC_NV bit. Logical blocks include user data and, if the medium is formatted with pro¬ 
tection information enabled, protection information. Logical blocks may or may not be removed from volatile 
cache and non-volatile cache as a result of the synchronize cache operation. 


Table 140 — SYNCHRONIZE CACHE (10) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (35h) 

1 

Reserved SYNC_NV IMMED Obsolete 

2 

(MSB) LOGICAL BLOCK ADDRESS 

5 

(LSB) 

6 

Reserved GROUP NUMBER 

7 

(MSB) NUMBER OF BLOCKS 

8 

(LSB) 

9 

CONTROL 


LOGICAL BLOCK ADDRESS field 

See clause 2.1.4 for the definition of the LOGICAL BLOCK ADDRESS field. 

GROUP NUMBER field 

See clause 2.1.4 for the definition of the GROUP NUMBER field. 

The SYNC_NV bit (see table 141) specifies whether the device server is required to synchronize volatile and 
non-volatile caches. 


Table 141 — SYNC_NV bit 


Code 

Device server requirement to synchronize logical blocks currently in the 

Volatile cache 

Non-volatile cache 

0 

Device server shall synchronize to the medium. 

Device server shall synchronize to the 
medium. 

1 

If a non-volatile cache is present, device server shall synchro¬ 
nize to non-volatile cache or the medium. If a non-volatile 
cache is not present, device server shall synchronize to the 
medium. 

No requirement. 


IMMED (Immediate) bit 

0 An immediate (IMMED) bit set to zero specifies that the device server shall not return status until the operation has 
been completed. 

1 An IMMED bit set to one specifies that the device server shall return status as soon as the CDB has been validated. 
If the IMMED bit is set to one and the device server does not support the IMMED bit, the device server shall termi¬ 
nate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the addi- 
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tional sense code set to INVALID FIELD IN CDB. 


NUMBER OF BLOCKS field 

The NUMBER OF BLOCKS field specifies the number of logical blocks that shall be synchronized, starting with the logical 
block specified by the LOGICAL BLOCK ADDRESS field. A NUMBER OF BLOCKS field set to zero specifies that all logical 
blocks starting with the one specified in the LOGICAL BLOCK ADDRESS field to the last logical block on the medium shall 
be synchronized. If the logical block address plus the number of blocks exceeds the capacity of the medium, the device 
server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and 
the additional sense code set to LOGICAL BLOCK ADDRESS OUT OF RANGE. 

A logical block within the range that is not in cache is not considered an error. 


3.47 SYNCHRONIZE CACHE (16) command 

The SYNCHRONIZE CACHE (16) command (see table 142) requests that the device server ensure that the 
specified logical blocks have their most recent data values recorded in non-volatile cache and/or on the 
medium, based on the SYNC_NV bit. Logical blocks include user data and, if the medium is formatted with pro¬ 
tection information enabled, protection information. Logical blocks may or may not be removed from volatile 
cache and non-volatile cache as a result of the synchronize cache operation. 


Table 142 — SYNCHRONIZE CACHE (16) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (91 h) 

1 

Reserved SYNC_NV IMMED Reserved 

2 

(MSB) LOGICAL BLOCK ADDRESS 

9 

(LSB) 

10 

(MSB) NUMBER OF BLOCKS 

13 

(LSB) 

14 

Reserved GROUP NUMBER 

15 

CONTROL 


See the SYNCHRONIZE CACHE (10) command (see 3.46) for the definitions of the fields in this command. 
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3.48 


TEST UNIT READY command 


The TEST UNIT READY command (see table 143) provides a means to check if the logical unit is ready. This 
is not a request for a self-test. If the logical unit is able to accept an appropriate medium-access command 
without returning CHECK CONDITION status, this command shall return a GOOD status. If the logical unit is 
unable to become operational or is in a state such that an application client action (e.g., START UNIT com¬ 
mand) is required to make the logical unit ready, the command shall be terminated with CHECK CONDITION 
status, with the sense key set to NOT READY. 


Table 143 — TEST UNIT READY command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (OOh) 

1 

Reserved 

4 


5 

CONTROL 


Table 144 defines the suggested GOOD and CHECK CONDITION status responses to the TEST UNIT 
READY command. Other conditions, including deferred errors, may result in other responses (e.g., BUSY or 
RESERVATION CONFLICT status). 


Table 144 — Preferred TEST UNIT READY responses 


Status 

Sense Key 

Additional Sense Code 

GOOD 

not applicable 

not applicable 

CHECK CONDITION 

ILLEGAL REQUEST 

LOGICAL UNIT NOT SUPPORTED 

CHECK CONDITION 

NOT READY 

LOGICAL UNIT DOES NOT RESPOND TO SELECTION 

CHECK CONDITION 

NOT READY 

MEDIUM NOT PRESENT 

CHECK CONDITION 

NOT READY 

LOGICAL UNIT NOT READY, CAUSE NOT REPORTABLE 

CHECK CONDITION 

NOT READY 

LOGICAL UNIT IS IN PROCESS OF BECOMING READY 

CHECK CONDITION 

NOT READY 

LOGICAL UNIT NOT READY, INITIALIZING COMMAND 

REQUIRED 

CHECK CONDITION 

NOT READY 

LOGICAL UNIT NOT READY, MANUAL INTERVENTION 

REQUIRED 

CHECK CONDITION 

NOT READY 

LOGICAL UNIT NOT READY, FORMAT IN PROGRESS 
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3.49 


VERIFY (10) command 


The VERIFY (10) command (see table 145) requests that the device server verify the specified logical block(s) 
on the medium. Each logical block includes user data and may include protection information, based on the 
VRPROTECT field and the medium format. 

If the RTO_EN bit is set to one in the READ CAPACITY (16) parameter data (see 3.27), the device server shall 
terminate this command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and 
the additional sense code set to INVALID COMMAND OPERATION CODE. 

Note. This command description is referenced by the VERIFY (32) command, which is terminated when 
the RTO_EN bit is set to zero rather than one. 


Table 145 — VERIFY (10) command 


Bit 

Byte 

7 

6 5 

4 3 2 1 0 

0 

OPERATION CODE (2Fh) 

1 

VRPROTECT DPO Reserved BYTCHK Obsolete 

2 

(MSB) 


LOGICAL BLOCK ADDRESS 

5 


(LSB) 

6 

RESTRICTED 
FOR MMC-4 

Reserved 

GROUP NUMBER 

7 

(MSB) 


VERIFICATION LENGTH 

8 


(LSB) 

9 

CONTROL 


Logical units that contain cache shall write referenced cached logical blocks to the medium for the logical unit 
(e.g., as they would do in response to a SYNCHRONIZE CACHE command (see 3.46 and 3.47) with the 
SYNC_NV bit set to zero, the LOGICAL BLOCK ADDRESS field set to the value of the VERIFY command’s 
LOGICAL BLOCK ADDRESS field, and the NUMBER OF BLOCKS field set to the value of the VERIFY com¬ 
mand’s VERIFICATION LENGTH field). 

See the READ (10) command (see 3.20) for the definition of the DPO bit. See clause 2.1.4 for the definition of 
the LOGICAL BLOCK ADDRESS field. See clause 2.1.4 for the definition of the GROUP NUMBER field. 

If the Verify Error Recovery mode page (see 4.3.21) is implemented, then the current settings in that page 
specify the verification criteria. If the Verify Error Recovery mode page is not implemented, then the verification 
criteria is vendor-specific. 

BYTCHK bit 

0 If the byte check (BYTCHK) bit is set to zero, the device server shall: 

a) perform a medium verification with no data comparison and not transfer any data from the data-out buffer; and 

b) check protection information read from the medium based on the VRPROTECT field as described in table 146. 
1 If the BYTCHK bit is set to one, the device server shall: 

a) perform a byte-by-byte comparison of user data read from the medium and user data transferred from the data- 
out buffer; 

b) check protection information read from the medium based on the VRPROTECT field as described in table 147; 

c) check protection transferred from the data-out buffer based on the VRPROTECT field as described in 
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table 148; and 


d) perform a byte-by-byte comparison of protection information read from the medium and transferred from the 
data-out buffer based on the VRPROTECT field as described in table 149. 

The order of the user data and protection information checks and comparisons is vendor-specific. 

If a byte-by-byte comparison is unsuccessful for any reason, the device server shall terminate the command 
with CHECK CONDITION status with the sense key set to MISCOMPARE and the additional sense code set to 
the appropriate value for the condition. 

VERIFICATION LENGTH field 

The VERIFICATION LENGTH field specifies the number of contiguous logical blocks that shall be verified, starting with the 
logical block specified by the LOGICAL BLOCK ADDRESS field. If the bytchk bit is set to one, the verification length 
field also specifies the number of logical blocks that the device server shall transfer from the data-out buffer. A verification 
length field set to zero specifies that no logical blocks shall be verified. This condition shall not be considered as an error. 
Any other value specifies the number of logical blocks that shall be verified. If the logical block address plus the verification 
length exceeds the capacity of the medium, the device server shall terminate the command with CHECK CONDITION sta¬ 
tus with the sense key set to ILLEGAL REQUEST and the additional sense code set to LOGICAL BLOCK ADDRESS OUT 
OF RANGE. The VERIFICATION LENGTH field is constrained by the MAXIMUM TRANSFER LENGTH field in the Block 
Limits VPD page. 

If the BYTCHK bit is set to zero, the device server shall check the protection information read from the medium 
based on the VRPROTECT field as described in table 146. 


Table 146 — VRPROTECT field with BYTCHK set to zero - medium (Sheet 1 of 3) 


Code 

Logical unit 
formatted 
with 

protection 

information 

Field in 
protection 
information h 

Extended 
INQUIRY Data 
VPD page bit 
value f 

If check fails d e , additional sense code 



LOGICAL 

BLOCK 

GUARD 

GRDCHK= 1 

LOGICAL BLOCK GUARD CHECK FAILED 



GRDCHK = 0 

No check performed 


Yes 

LOGICAL 
BLOCK APPLI¬ 
CATION TAG 

APPCHK = 1 C 

LOGICAL BLOCK APPLICATION TAG CHECK 
FAILED 

000b 

APPCHK = 0 

No check performed 



LOGICAL 
BLOCK REF¬ 
ERENCE TAG 

REFCHK = 1 i 

LOGICAL BLOCK REFERENCE TAG CHECK 

FAILED 



REFCHK = 0 

No check performed 


No 

No protection information on the medium to check. Only user data is checked. 
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Table 146 — VRPROTECT field with BYTCHK set to zero - medium (Sheet 2 of 3) 


Code 

Logical unit 
formatted 
with 

protection 

information 

Field in 
protection 
information h 

Extended 
INQUIRY Data 
VPD page bit 
value f 

If check fails d e , additional sense code 



LOGICAL 

BLOCK 

GUARD 

GRDCHK= 1 

LOGICAL BLOCK GUARD CHECK FAILED 



GRD_CHK = 0 

No check performed 

001b 

101b b 

Yes 

LOGICAL 
BLOCK APPLI¬ 
CATION TAG 

APP_CHK = 1 C 

LOGICAL BLOCK APPLICATION TAG CHECK 
FAILED 

APPCHK = 0 

No check performed 



LOGICAL 
BLOCK REF¬ 
ERENCE TAG 

REFCHK = 1 ' 

LOGICAL BLOCK REFERENCE TAG CHECK 

FAILED 



REF_CHK = 0 

No check performed 


No 

Error condition a 



LOGICAL 

BLOCK 

GUARD 

No check performed 


Yes 

LOGICAL 
BLOCK APPLI¬ 
CATION TAG 

APP_CHK = 1 c 

LOGICAL BLOCK APPLICATION TAG CHECK 
FAILED 

010b b 

APPCHK = 0 

No check performed 



LOGICAL 
BLOCK REF¬ 
ERENCE TAG 

REFCHK = 1 ' 

LOGICAL BLOCK REFERENCE TAG CHECK 

FAILED 



REF_CHK = 0 

No check performed 


No 

Error condition a 



LOGICAL 

BLOCK 

GUARD 

No check performed 

011b b 

Yes 

LOGICAL 
BLOCK APPLI¬ 
CATION TAG 

No check performed 



LOGICAL 
BLOCK REF¬ 
ERENCE TAG 

No check performed 


No 

Error condition a 
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Table 146 — VRPROTECT field with BYTCHK set to zero - medium (Sheet 3 of 3) 


Code 

Logical unit 
formatted 
with 

protection 

information 

Field in 
protection 
information h 

Extended 
INQUIRY Data 
VPD page bit 
value f 

If check fails d e , additional sense code 



logical block 
guard 

GRDCHK= 1 

LOGICAL BLOCK GUARD CHECK FAILED 



GRDCHK=0 

No check performed 

100b b 

Yes 

logical block 
application tag 

No check performed 



logical block 
reference tag 

No check performed 


No 

Error condition a 

101b- 

111b 

Reserved 


a A verify operation to a logical unit that supports protection information and has not been formatted with protection 
information shall be terminated with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and 
the additional sense code set to INVALID FIELD IN CDB. 

b If the logical unit does not support protection information the requested command should be terminated with CHECK 
CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID 
FIELD IN CDB. 

c The device server shall check the logical block application tag if it has knowledge of the contents of the LOGICAL 
BLOCK APPLICATION TAG field. If the VERIFY (32) command (see 3.52) is used and the ATO bit is set to one in the 
Control mode page (see SPC-4), this knowledge is acquired from the EXPECTED LOGICAL BLOCK APPLICATION 
TAG field and the LOGICAL BLOCK APPLICATION TAG MASK field in the CDB. Otherwise, this knowledge may be 
obtained by a method not defined by this standard, 
d If an error is reported, the sense key shall be set to ABORTED COMMAND, 
e If multiple errors occur, the selection of which error to report is not defined by this standard, 
f See the Extended INQUIRY Data VPD page (see SPC-4) for the definitions of the GRDCHK bit, the APP CHK bit, 
and the REF CHK bits. 

g If the application client or device server detects a LOGICAL BLOCK APPLICATION TAG field set to FFFFh, the 
checking of all protection information shall be disabled for the associated logical block. 
h If the application client or device server detects a: 

a) LOGICAL BLOCK APPLICATION TAG field set to FFFFh and type 1 protection (see SBC-4) or type 2 protection 
(see SBC-4) is enabled; or 

b) LOGICAL BLOCK APPLICATION TAG field set to FFFFh, LOGICAL BLOCK REFERENCE TAG field set to 
FFFF FFFFh, and type 3 protection (see SBC-4) is enabled, 

then the device server shall not check any protection information in the associated logical block. 

' If type 1 protection is enabled, the device server checks the logical block reference tag by comparing it to 
the lower 4 bytes of the LBA associated with the logical block. If type 2 protection or type 3 protection is 
enabled, the device server checks the logical block reference tag if it has knowledge of the contents of 
the LOGICAL BLOCK REFERENCE TAG field. If type 2 protection is enabled, then this knowledge may 
be acquired through the EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG field in a VERIFY 
(32) command (see 3.52). If type 3 protection is enabled, then the method for acquiring this knowledge is 
not defined by this standard. 
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If the BYTCHK bit is set to one, the device server shall check the protection information read from the medium 
based on the VRPROTECT field as described in table 147. 

Table 147 — VRPROTECT field with BYTCHK set to one - medium (Sheet 1 of 2) 


Code 

Logical unit 
formatted 
with 

protection 

information 

Field in protection 
information h 

Extended 
INQUIRY Data 
VPD page bit 
value f 

If check fails d e , additional sense code 

000b 

Yes 

LOGICAL BLOCK 
GUARD 

GRDCHK= 1 

LOGICAL BLOCK GUARD CHECK FAILED 

GRDCHK = 0 

No check performed 

LOGICAL BLOCK 
APPLICATION TAG 

APPCHK = 1 c g 

LOGICAL BLOCK APPLICATION TAG CHECK 
FAILED 

APPCHK = 0 

No check performed 

LOGICAL BLOCK 
REFERENCE TAG 

REF_CHK = 1 i 

LOGICAL BLOCK REFERENCE TAG CHECK 
FAILED 

REF_CHK = 0 

No check performed 

No 

No protection information on the medium available to check 

001b 

010b 

011b 

100b 

101b 

b 

Yes 

LOGICAL BLOCK 
GUARD 

No check performed 

LOGICAL BLOCK 
APPLICATION TAG 

No check performed 

LOGICAL BLOCK 
REFERENCE TAG 

No check performed 

No 

Error condition a 

110b- 

111b 

Reserved 
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Table 147 — VRPROTECT field with BYTCHK set to one - medium (Sheet 2 of 2) 


Code 

Logical unit 
formatted 
with 

protection 

information 

Field in protection 
information h 

Extended 
INQUIRY Data 
VPD page bit 
value f 

If check fails d e , additional sense code 







a A verify operation to a logical unit that supports protection information and has not been formatted with 
protection information shall be terminated with CHECK CONDITION status with the sense key set to 
ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 
b If the logical unit does not support protection information the requested command should be terminated 
with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense 
code set to INVALID FIELD IN CDB. 

c The device server shall check the logical block application tag if it has knowledge of the contents of the 
LOGICAL BLOCK APPLICATION TAG field. If the VERIFY (32) command (see 3.52) is used and the ATO 
bit is set to one in the Control mode page (see SPC-4), this knowledge is acquired from the EXPECTED 
LOGICAL BLOCK APPLICATION TAG field and the LOGICAL BLOCK APPLICATION TAG MASK field in 
the CDB. Otherwise, this knowledge may be obtained by a method not defined by this standard. 
d If an error is reported, the sense key shall be set to ABORTED COMMAND. 
e If multiple errors occur, the selection of which error to report is not defined by this standard. 
f See the Extended INQUIRY Data VPD page (see SPC-4) for the definitions of the GRD CHK bit, the 
APP CHK bit, and the REF CHK bit. 

9 If the application client or device server detects a: 

a) logical block application tag field set to FFFFh and type 1 protection or type 2 protection is enabled; 
or 

b) logical block application tag field set to FFFFh, logical block reference tag field set to FFFF FFFFh, 
and type 3 protection is enabled, 

then the device server shall not check any protection information in the associated logical block. 
h If type 1 protection is enabled, the device server checks the logical block reference tag by comparing it to 
the lower 4 bytes of the LBA associated with the logical block. If type 2 protection or type 3 protection is 
enabled, the device server checks the logical block reference tag if it has knowledge of the contents of 
the logical block reference tag field. If type 2 protection is enabled, then this knowledge may be acquired 
through the expected initial logical block reference tag field in a VERIFY (32) command (see 3.52). If type 
3 protection is enabled, then the method for acquiring this knowledge is not defined by this standard. 
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If the BYTCHK bit is set to one, the device server shall check the protection information transferred from the 
data-out buffer based on the VRPROTECT field as described in table 148. 

Table 148 — VRPROTECT field with BYTCHK set to one - data-out buffer (Sheet 1 of 2) 


Code 

Logical unit 
formatted with 
protection 
information 

Field in 
protection 
information 

Device server 
check 

If check fails d e , additional sense code 

000b 

Yes 

No protection information received from application client to check 

No 

No protection information received from application client to check 

001b b 

Yes 

LOGICAL BLOCK 
GUARD 

Shall 

LOGICAL BLOCK GUARD CHECK FAILED 

LOGICAL BLOCK 
APPLICATION 
TAG 

May c 

LOGICAL BLOCK APPLICATION TAG CHECK 
FAILED 

LOGICAL BLOCK 
REFERENCE 
TAG 

Shall f 

LOGICAL BLOCK REFERENCE TAG CHECK 
FAILED 

No 

Error condition a 

010b » 

Yes 

LOGICAL BLOCK 
GUARD 

Shall not 

No check performed 

LOGICAL BLOCK 
APPLICATION 
TAG 

May c 

LOGICAL BLOCK APPLICATION TAG CHECK 
FAILED 

LOGICAL BLOCK 
REFERENCE 
TAG 

May f 

LOGICAL BLOCK REFERENCE TAG CHECK 
FAILED 

No 

Error condition a 

011b b 

Yes 

LOGICAL BLOCK 
GUARD 

Shall not 

No check performed 

LOGICAL BLOCK 
APPLICATION 
TAG 

Shall not 

No check performed 

LOGICAL BLOCK 
REFERENCE 
TAG 

Shall not 

No check performed 

No 

Error condition a 
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Table 148 — VRPROTECT field with BYTCHK set to one - data-out buffer (Sheet 2 of 2) 


Code 

Logical unit 
formatted with 
protection 
information 

Field in 
protection 
information 

Device server 
check 

If check fails d e , additional sense code 



LOGICAL BLOCK 
GUARD 

Shall 

LOGICAL BLOCK GUARD CHECK FAILED 

100b b 

Yes 

LOGICAL BLOCK 
APPLICATION 
TAG 

Shall not 

No check performed 



LOGICAL BLOCK 
REFERENCE 
TAG 

Shall not 

No check performed 


No 

Error condition a 



LOGICAL 
BLOCK GUARD 

Shall 

LOGICAL BLOCK GUARD CHECK FAILED 

101b b 

Yes 

LOGICAL 
BLOCK APPLI¬ 
CATION TAG 

May c 

LOGICAL BLOCK APPLICATION TAG 
CHECK FAILED 



LOGICAL 
BLOCK REFER¬ 
ENCE TAG 

May f 

LOGICAL BLOCK REFERENCE TAG 
CHECK FAILED 


No 

Error condition a 

110b- 

111b 

Reserved 


a A verify operation to a logical unit that supports protection information and has not been formatted with 
protection information shall be terminated with CHECK CONDITION status with the sense key set to 
ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 
b If the logical unit does not support protection information the requested command should be terminated 
with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional 
sense code set to INVALID FIELD IN CDB. 

c The device server may check the logical block application tag if the ATO bit is set to one in the Control 
mode page (see SPC-4) and if it has knowledge of the contents of the logical block application tag 
field. If the VERIFY (32) command (see 3.52) is used, this knowledge is obtained from the expected 
LOGICAL BLOCK APPLICATION TAG field and the LOGICAL BLOCK APPLICATION TAG MASK field in the CDB. 
Otherwise, this knowledge is obtained by a method not defined by this standard. 
d If an error is reported, the sense key shall be set to ABORTED COMMAND. 
e If multiple errors occur, the selection of which error to report is not defined by this standard. 
f If type 1 protection is enabled, the device server checks the logical block reference tag by comparing it 
to the lower 4 bytes of the LBA associated with the logical block. If type 2 protection or type 3 protection 
is enabled, the device server checks the logical block reference tag if it has knowledge of the contents of 
the logical block reference tag field. If type 2 protection is enabled, then this knowledge may be acquired 
through the expected initial logical block reference tag field in a VERIFY (32) command (see 3.52). If 
type 3 protection is enabled, then the method for acquiring this knowledge is not defined by this 
standard. 
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If the BYTCHK bit is set to one, the device server shall perform a byte-by-byte comparison of protection 
information transferred from the data-out buffer with protection information read from the medium based on the 
VRPROTECT field as described in table 149. 


Table 149 — VRPROTECT field with BYTCHK set to one - byte-by-byte comparison requirements 
(Sheet 1 of 2) 


Code 

Logical unit 
formatted 
with 

protection 

information 

Field 

Byte-by-byte 

Comparison 

If compare fails d e , additional sense code 

000b 

Yes 

No protection information received from application client to compare. Only user data is 
compared within each logical block. 

No 

No protection information or the medium or received from application client to compare. 
Only user data is compared within each logical block. 

001b 
011b 
100b b 

Yes 

LOGICAL BLOCK 
GUARD 

Shall 

LOGICAL BLOCK GUARD CHECK FAILED 

LOGICAL BLOCK 
APPLICATION TAG 
(ATO = 1) e 

Shall 

LOGICAL BLOCK APPLICATION TAG 
CHECK FAILED 

LOGICAL BLOCK 
APPLICATION TAG 
(ATO = 0) f 

Shall not 

No compare performed 

LOGICAL BLOCK REF¬ 
ERENCE TAG 

Shall 

LOGICAL BLOCK REFERENCE TAG 

CHECK FAILED 

No 

Error condition a 
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Table 149 — VRPROTECT field with BYTCHK set to one - byte-by-byte comparison requirements 
(Sheet 2 of 2) 


Code 

Logical unit 
formatted 
with 

protection 

information 

Field 

Byte-by-byte 

Comparison 

If compare fails d e , additional sense code 



LOGICAL BLOCK 
GUARD 

Shall not 

No compare performed 


Yes 

LOGICAL BLOCK 
APPLICATION TAG 
(ATO = 1) e 

Shall 

LOGICAL BLOCK APPLICATION TAG 
CHECK FAILED 

010b b 

LOGICAL BLOCK 
APPLICATION TAG 
(ATO = 0) f 

Shall not 

No compare performed 



LOGICAL BLOCK REF¬ 
ERENCE TAG 

Shall 

LOGICAL BLOCK REFERENCE TAG 

CHECK FAILED 


No 

Error condition a 



LOGICAL BLOCK 
GUARD 

Shall 

LOGICAL BLOCK GUARD CHECK FAILED 


Yes 

LOGICAL BLOCK 
APPLICATION TAG 
(ATO = 1) E 

Shall 

LOGICAL BLOCK APPLICATION TAG 
CHECK FAILED 

101b b 

LOGICAL BLOCK 
APPLICATION TAG 
(ATO = 0) F 

Shall not 

No compare performed 



LOGICAL BLOCK REF¬ 
ERENCE TAG 

Shall 

LOGICAL BLOCK REFERENCE TAG 

CHECK FAILED 


No 

Error condition a 

110b- 

111b 

Reserved 


a A verify operation to a logical unit that supports protection information and has not been formatted with protection 
information shall be terminated with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and 
the additional sense code set to INVALID FIELD IN CDB. 
b If the logical unit does not support protection information the requested command should be terminated with 
CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to 
INVALID FIELD IN CDB. 

c If an error is reported, the sense key shall be set to MISCOMPARE. 
d If multiple errors occur, the selection of which error to report is not defined by this standard, 
e If the ATO bit is set to one in the Control mode page (see SPC-4), the logical block application tag shall not be 
modified by a device server. 

f If the ATO bit is set to zero in the Control mode page (see SPC-4), the logical block application tag may be modified 
by a device server. 
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3.50 


VERIFY (12) command 


The VERIFY (12) command (see table 150) requests that the device server verify the specified logical block(s) 
on the medium. Each logical block includes user data and may include protection information, based on the 
VRPROTECT field and the medium format. 

If the RTO_EN bit is set to one in the READ CAPACITY (16) parameter data (see 3.26), the device server shall 
terminate this command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and 
the additional sense code set to INVALID COMMAND OPERATION CODE. 


Table 150 — VERIFY (12) command 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

OPERATION CODE (AFh) 

1 

VRPROTECT 


DPO 

Reserved 

BYTCHK 

Obsolete 

2 

(MSB) 


LOGICAL BLOCK ADDRESS 



5 








(LSB) 

6 

(MSB) 



VERIFICATION LENGTH 




9 








(LSB) 

10 

RESTRICT 
ED FOR 
MMC-4 

Reserved 

GROUP NUMBER 

11 

CONTROL 


See the VERIFY (10) command (see 3.49) for the definitions of the fields in this command. 
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3.51 VERIFY (16) command 

The VERIFY (16) command (see table 151) requests that the device server verify the specified logical block(s) 
on the medium. Each logical block includes user data and may include protection information, based on the 
VRPROTECT field and the medium format. 

If the RTO_EN bit is set to one in the READ CAPACITY (16) parameter data (see 3.26), the device server shall 
terminate this command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and 
the additional sense code set to INVALID COMMAND OPERATION CODE. 


Table 151 — VERIFY (16) command 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

OPERATION CODE (8Fh) 

1 

VRPROTECT 


DPO 

Reserved 

BYTCHK 

Reserved 

2 

(MSB) 


LOGICAL BLOCK ADDRESS 



9 








(LSB) 

10 

(MSB) 



VERIFICATION LENGTH 



13 








(LSB) 

14 

Restricted 
for MMC-4 

Reserved 

GROUP NUMBER 

15 

CONTROL 


See the VERIFY (10) command (see 3.49) for the definitions of the fields in this command. 
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3.52 VERIFY (32) command 

The VERIFY (32) command (see table 152) requests that the device server verify the specified logical block(s) 
on the medium. Each logical block includes user data and may include protection information, based on the 
VRPROTECT field and the medium format. 

The VERIFY (32) command shall only be processed if type 2 protection is enabled (see SPC-4).. 

Table 152 — VERIFY (32) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (7Fh) 

1 

CONTROL 

2 

Reserved 

5 


6 

Reserved GROUP NUMBER 

7 

ADDITIONAL CDB LENGTH (18h) 

8 

(MSB) SERVICE ACTION (OOOAh) 

9 

(LSB) 

10 

VRPROTECT DPO Reserved BYTCHK Reserved 

11 

Reserved 

12 

(MSB) LOGICAL BLOCK ADDRESS 

19 

(LSB) 

20 

(MSB) EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG 

23 

(LSB) 

24 

(MSB) EXPECTED LOGICAL BLOCK APPLICATION TAG 

25 

(LSB) 

26 

(MSB) LOGICAL BLOCK APPLICATION TAG MASK 

27 

(LSB) 

28 

(MSB) VERIFICATION LENGTH 

31 

(LSB) 


See the VERIFY (10) command (see 3.49) for the definitions of the GROUP NUMBER field, VRPROTECT 
field, DPO bit, BYTCHK bit, LOGICAL BLOCK ADDRESS field, and VERIFICATION LENGTH field. 

When checking of the LOGICAL BLOCK REFERENCE TAG field is enabled (see table 146, table 147, 
table 148, and table 149 in 3.49), the EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG field contains 
the value of the LOGICAL BLOCK REFERENCE TAG field expected in the protection information of the first 
logical block accessed by the command instead of a value based on the LBA. 
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If the ATO bit is set to one in the Control mode page (see SPC-4) and checking of the LOGICAL BLOCK 
APPLICATION TAG field is enabled (see table 146, table 147, table 148, and table 149 in 3.49), the LOGICAL 
BLOCK APPLICATION TAG MASK field contains a value that is a bit mask for enabling the checking of the 
LOGICAL BLOCK APPLICATION TAG field in the protection information for each logical block accessed by the 
command. A LOGICAL BLOCK APPLICATION TAG MASK bit set to one enables the checking of the corre¬ 
sponding bit of the EXPECTED LOGICAL BLOCK APPLICATION TAG field with the corresponding bit of the 
LOGICAL BLOCK APPLICATION TAG field in the protection information. 

If the ATO bit is set to one in the Control mode page (see SPC-4) and checking of the LOGICAL BLOCK 
APPLICATION TAG field is disabled (see table 146, table 147, table 148, and table 149 in 3.49), or if the ATO 
bit is set to zero, the LOGICAL BLOCK APPLICATION TAG MASK field and the EXPECTED LOGICAL 
BLOCK APPLICATION TAG field shall be ignored. 

The LOGICAL BLOCK APPLICATION TAG MASK field and the EXPECTED LOGICAL BLOCK APPLICATION 
TAG field shall be ignored if: 

a) the ATO bit is set to zero; or 

b) the ATO bit is set to one in the Control mode page (see SPC-4) and checking of the LOGICAL BLOCK 
APPLICATION TAG field is disabled (see table 146, table 147, table 148, and table 149 in 3.49). 
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3.53 


WRITE (6) command 


The WRITE (6) command (see table 153) requests that the device server transfer the specified logical block(s) 
from the data-out buffer and write them. Each logical block transferred includes user data but does not include 
protection information. Each logical block written includes user data and, if the medium is formatted with pro¬ 
tection information enabled, protection information. 


Table 153 — WRITE (6) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (OAh) 

1 

Reserved (MSB) 

2 

LOGICAL BLOCK ADDRESS 

3 

(LSB) 

4 

TRANSFER LENGTH 

5 

CONTROL 


The cache control bits are not provided for this command. Direct-access block devices with cache may have 
values for the cache control bits that may affect the WRITE (6) command, however no default value is defined 
by this standard. If explicit control is required, the WRITE (10) command should be used. 

LOGICAL BLOCK ADDRESS field 

See clause 2.1.4 for the definition of the LOGICAL BLOCK ADDRESS field. 

TRANSFER LENGTH field 

The TRANSFER LENGTH field specifies the number of contiguous logical blocks of data that shall be transferred from the 
data-out buffer and written, starting with the logical block specified by the LOGICAL BLOCK ADDRESS field. A TRANSFER 
LENGTH field set to zero specifies that 256 logical blocks shall be written. Any other value specifies the number of logical 
blocks that shall be written. If the logical block address plus the transfer length exceeds the capacity of the medium, the 
device server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST 
and the additional sense code set to LOGICAL BLOCK ADDRESS OUT OF RANGE. The TRANSFER LENGTH field is 
constrained by the MAXIMUM TRANSFER LENGTH field in the Block Limits VPD page. 

Note. For the WRITE (10) command, WRITE (12) command, WRITE (16) command, and WRITE (32) 
command, a TRANSFER LENGTFI field set to zero specifies that no logical blocks are transferred. 

If a WRITE (6) command is received after protection information is enabled the device server shall set the pro¬ 
tection information as follows as it writes each logical block to the medium: 

a) the LOGICAL BLOCK GUARD field set to a properly generated CRC (see SPC-4 4.16); 

b) the LOGICAL BLOCK REFERENCE TAG field set to: 

1. the least significant four bytes of the LBA, if type 1 protection (see SPC-4) is enabled; 

or 

2. FFFFFFFFh, if type 2 protection or type 3 protection is enabled 

and 

c) the LOGICAL BLOCK APPLICATION TAG field set to: 

1. FFFFh, if the ATO bit is set to one in the Control mode page (see SPC-4); or 

2. any value, if the ATO bit is set to zero in the Control mode page (see SPC-4). 
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3.54 


WRITE (10) command 


The WRITE (10) command (see table 154) requests that the device server transfer the specified logical 
block(s) from the data-out buffer and write them. Each logical block transferred includes user data and may 
include protection information, based on the WRPROTECT field and the medium format. Each logical block 
written includes user data and, if the medium is formatted with protection information enabled, protection infor¬ 
mation. 


Table 154 — WRITE (10) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (2Ah) 

1 

WRPROTECT DPO FUA Reserved FUA_NV Obsolete 

2 

(MSB) LOGICAL BLOCK ADDRESS 

5 

(LSB) 

6 

Reserved GROUP NUMBER 

7 

(MSB) TRANSFER LENGTH 

8 

(LSB) 

9 

CONTROL 


See the READ (10) command (see 3.20) for the definition of the DPO bit. See clause 2.1.4 for the definition of 
the LOGICAL BLOCK ADDRESS field. See clause 2.1.4 and SPC-4 for the definition of the GROUP NUMBER 
field. 

The device server shall check the protection information transferred from the data-out buffer based on the 
WRPROTECT field as described in table 155. 


Table 155 — WRPROTECT field (Sheet 1 of 3) 


Code 

Logical unit 
formatted 
with 

protection 

information 

Field in 
protection 
information 

Device 

server 

check 

If check fails d ■> additional sense code 

000b 

Yes f 9 h 

No protection information received from application client to check 

No 

No protection information received from application client to check 

001b » 

Yes e 

logical block guard 

Shall 

LOGICAL BLOCK GUARD CHECK FAILED 

logical block appli¬ 
cation tag 

May c 

LOGICAL BLOCK APPLICATION TAG CHECK FAILED 

logical block refer¬ 
ence tag 

Shall k 

LOGICAL BLOCK REFERENCE TAG CHECK FAILED 

No a 

No protection information available to check 
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Table 155 — WRPROTECT field (Sheet 2 of 3) 


Code 

Logical unit 
formatted 
with 

protection 

information 

Field in 
protection 
information 

Device 

server 

check 

If check fails d ■> additional sense code 

010b b 

Yes e 

logical block guard 

Shall not 

No check performed 

logical block appli¬ 
cation tag 

May c 

LOGICAL BLOCK APPLICATION TAG CHECK FAILED 

logical block refer¬ 
ence tag 

May k 

LOGICAL BLOCK REFERENCE TAG CHECK FAILED 

No a 

No protection information available to check 

011b » 

Yes e 

logical block guard 

Shall not 

No check performed 

logical block appli¬ 
cation tag 

Shall not 

No check performed 

logical block refer¬ 
ence tag 

Shall not 

No check performed 

No a 

No protection information available to check 

100b b 

Yes a 

logical block guard 

Shall 

LOGICAL BLOCK GUARD CHECK FAILED 

logical block appli¬ 
cation tag 

Shall not 

No check performed 

logical block refer¬ 
ence tag 

Shall not 

No check performed 

No a 

No protection information available to check 

101b b 

Yes a 

logical block guard 

Shall 

LOGICAL BLOCK GUARD CHECK FAILED 

logical block appli¬ 
cation tag 

May c 

LOGICAL BLOCK APPLICATION TAG CHECK FAILED 

logical block refer¬ 
ence tag 

May i 

LOGICAL BLOCK REFERENCE TAG CHECK FAILED 

No a 

No protection information available to check 
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Table 155 — WRPROTECT field (Sheet 3 of 3) 



Logical unit 
formatted 

Field in 

Device 


Code 

with 

protection 

information 

protection 

information 

server 

check 

If check fails d ■> additional sense code 


110b- 

111b Reserved 


a A write operation to a logical unit that supports protection information and has not been formatted with 
protection information shall be terminated with CHECK CONDITION status with the sense key set to 
ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN CDB. 
b If the logical unit does not support protection information the requested command should be terminated 
with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense 
code set to INVALID FIELD IN CDB. 

c The device server may check the logical block application tag if the ATO bit is set to one in the Control 
mode page (see SPC-4) and if it has knowledge of the contents of the logical block application tag 
field. If the WRITE (32) command (see 3.57) is used, this knowledge is obtained from the EXPECTED 
LOGICAL BLOCK APPLICATION TAG field and the LOGICAL BLOCK APPLICATION TAG MASK field in 
the CDB. Otherwise, this knowledge is obtained by a method not defined by this standard. 
d If an error is reported, the sense key shall be set to ABORTED COMMAND. 

e Device server shall preserve the contents of protection information (e.g., write to medium, store in non¬ 
volatile memory). 

f The device server shall write a properly generated CRC into each logical block guard field. 

9 If the P_TYPE field is set to 000b in the READ CAPACITY (16) parameter data, the device server shall 
write the least significant four bytes of each LBA into the LOGICAL BLOCK REFERENCE TAG field of 
each of the written logical blocks. If the P_TYPE field is not set to 000b, the device server shall write a 
value of FFFFFFFFh into the logical block reference tag field of each of the written logical blocks. 
h If the ATO bit is set to one in the Control mode page (see SPC-4), the device server shall write FFFFh 
into each LOGICAL BLOCK APPLICATION TAG field. If the ATO bit is set to zero, the device server may 
write any value into each LOGICAL BLOCK APPLICATION TAG field. 

' If multiple errors occur, the selection of which error to report is not defined by this standard, 
i If type 1 protection is enabled, the device server checks the logical block reference tag by comparing it to 
the lower 4 bytes of the LBA associated with the logical block. If type 2 protection or type 3 protection is 
enabled, the device server checks the logical block reference tag if it has knowledge of the contents of 
the logical block reference tag field. If type 2 protection is enabled, then this knowledge may be acquired 
through the expected initial logical block reference tag field in a WRITE (32) command (see 3.57). If type 
3 protection is enabled, then the method for acquiring this knowledge is not defined by this standard. 
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The force unit access (FUA) and force unit access non-volatile cache (FUA_NV) bits are defined in table 156. 


Table 156 — Force unit access for write operations 


FUA 

FUA_NV 

Description 

0 

0 

The device server shall write the logical blocks to volatile cache, non-volatile cache, and/or the 
medium. 

0 

1 

If the NVSUP bit is set to one in the Extended INQUIRY Data VPD page (see SPC-4), the device 
server shall write the logical blocks to non-volatile cache and/or the medium. 

If the NV SUP bit is set to zero in the Extended INQUIRY Data VPD page (see SPC-4), the device 
server shall write the logical blocks to volatile cache, non-volatile cache, and/or the medium. 

1 

0 or 1 

The device server shall write the logical blocks to the medium, and shall not return GOOD status 
until the logical blocks have actually been written on the medium. 


If logical blocks are transferred directly to a cache, the device server may return GOOD status prior to writing 
the logical blocks to the medium. Any error that occurs after the GOOD status is returned is a deferred error, 
and information regarding the error is not reported until a subsequent command. 

TRANSFER LENGTH field 

The TRANSFER LENGTH field specifies the number of contiguous logical blocks of data that shall be trans¬ 
ferred from the data-out buffer and written, starting with the logical block specified by the LOGICAL BLOCK 
ADDRESS field. A TRANSFER LENGTH field set to zero specifies that no logical blocks shall be written. This 
condition shall not be considered an error. Any other value specifies the number of logical blocks that shall be 
written. If the logical block address plus the transfer length exceeds the capacity of the medium, the device 
server shall terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL 
REQUEST and the additional sense code set to LOGICAL BLOCK ADDRESS OUT OF RANGE. The TRANS¬ 
FER LENGTH field is constrained by the MAXIMUM TRANSFER LENGTH field in the Block Limits VPD page. 

Note. For the WRITE (6) command, a TRANSFER LENGTH field set to zero specifies that 256 logical 
blocks are transferred. 
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3.55 


WRITE (12) command 


The WRITE (12) command (see table 157) requests that the device server transfer the specified logical 
block(s) from the data-out buffer and write them. Each logical block transferred includes user data and may 
include protection information, based on the WRPROTECT field and the medium format. Each logical block 
written includes user data and, if the medium is formatted with protection information enabled, protection infor¬ 
mation. 


Table 157 — WRITE (12) command 


Bit 

Byte 

7 

6 5 

4 3 2 1 0 

0 

OPERATION CODE (AAh) 

1 

WRPROTECT DPO FUA Reserved FUA_NV Obsolete 

2 

(MSB) 


LOGICAL BLOCK ADDRESS 

5 


(LSB) 

6 

(MSB) 


TRANSFER LENGTH 

9 


(LSB) 

10 

RESTRICT 
ED FOR 
MMC-4 

Reserved 

GROUP NUMBER 

11 

CONTROL 


See the WRITE (10) command (see 3.54) for the definitions of the fields in this command. 
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3.56 


WRITE (16) command 


The WRITE (16) command (see table 158) requests that the device server transfer the specified logical 
block(s) from the data-out buffer and write them. Each logical block transferred includes user data and may 
include protection information, based on the WRPROTECT field and the medium format. Each logical block 
written includes user data and, if the medium is formatted with protection information enabled, protection infor¬ 
mation. 


Table 158 — WRITE (16) command 


Bit 

Byte 

7 

6 5 

4 3 2 1 0 

0 

OPERATION CODE (8Ah) 

1 

WRPROTECT DPO FUA Reserved FUA_NV Reserved 

2 

(MSB) 


LOGICAL BLOCK ADDRESS 

9 


(LSB) 

10 

(MSB) 


TRANSFER LENGTH 

13 


(LSB) 

14 

RESTRICT 
ED FOR 
MMC-4 

Reserved 

GROUP NUMBER 

15 

CONTROL 


See the WRITE (10) command (see 3.54) for the definitions of the fields in this command. 
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3.57 WRITE (32) command 

The WRITE (32) command (see table 159) requests that the device server transfer the specified logical 
block(s) from the data-out buffer and write them. Each logical block transferred includes user data and may 
include protection information, based on the WRPROTECT field and the medium format. Each logical block 
written includes user data and, if the medium is formatted with protection information enabled, protection infor¬ 
mation. 

The WRITE (32) command shall only be processed if type 2 protection is enabled (see SPC-4). 

RTO_EN bit 

0 If the RTO_EN bit is set to zero in the READ CAPACITY (16) parameter data (see 3.27), the device server shall ter¬ 
minate the WRITE (32) command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST 
and the additional sense code set to INVALID COMMAND OPERATION CODE. 

1 If the RTO_EN bit is set to one, the device server may process the command. 

Table 159 — WRITE (32) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (7Fh) 

1 

CONTROL 

2 

Reserved 

5 


6 

Reserved GROUP NUMBER 

7 

ADDITIONAL CDB LENGTH (18h) 

8 

(MSB) SERVICE ACTION (OOOBh) 

9 

(LSB) 

10 

WRPROTECT DPO FUA Reserved FUA_NV Reserved 

11 

Reserved 

12 

(MSB) LOGICAL BLOCK ADDRESS 

19 

(LSB) 

20 

(MSB) EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG 

23 

(LSB) 

24 

(MSB) EXPECTED LOGICAL BLOCK APPLICATION TAG 

25 

(LSB) 

26 

(MSB) LOGICAL BLOCK APPLICATION TAG MASK 

27 

(LSB) 

28 

(MSB) TRANSFER LENGTH 

31 

(LSB) 
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See the WRITE (10) command (see 3.54) for the definitions of the GROUP NUMBER field, the WRPROTECT 
field, the DPO bit, the FUA bit, the FUA_NV bit, the LOGICAL BLOCK ADDRESS field, and the TRANSFER 
LENGTH field. 

When checking of the LOGICAL BLOCK REFERENCE TAG field is enabled (see table 155 in 3.54), the 
EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG field contains the value of the LOGICAL BLOCK 
REFERENCE TAG field expected in the protection information of the first logical block accessed by the com¬ 
mand instead of a value based on the LBA. 

If the ATO bit is set to one in the Control mode page (see SPC-4) and checking of the LOGICAL BLOCK 
APPLICATION TAG field is enabled (see table 155 in 3.54), the LOGICAL BLOCK APPLICATION TAG MASK 
field contains a value that is a bit mask for enabling the checking of the LOGICAL BLOCK APPLICATION TAG 
field in the protection information for each logical block accessed by the command. A LOGICAL BLOCK 
APPLICATION TAG MASK bit set to one enables the checking of the corresponding bit of the EXPECTED 
LOGICAL BLOCK APPLICATION TAG field with the corresponding bit of the LOGICAL BLOCK APPLICATION 
TAG field in the protection information. 

The LOGICAL BLOCK APPLICATION TAG MASK field and the EXPECTED LOGICAL BLOCK APPLICATION TAG field Shall be 
ignored if: 

a) the ATO bit is set to zero; or 

the ATO bit is set to one in the Control mode page (see SPC-4) and checking of the logical block application 
tag field is disabled (see SPC-4). 
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3.58 


WRITE AND VERIFY (10) command 


The WRITE AND VERIFY (10) command (see table 160) requests that the device server transfer the specified 
logical block(s) from the data-out buffer, write them to the medium, and then verify that they are correctly writ¬ 
ten. Each logical block includes user data and may include protection information, based on the WRPROTECT 
field and the medium format. The logical blocks are only transferred once from the data-out buffer to the device 
server. 

If the RTO_EN bit is set to one in the READ CAPACITY (16) parameter data (see 3.27), the device server shall 
terminate this command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and 
the additional sense code set to INVALID COMMAND OPERATION CODE. 


Table 160 — WRITE AND VERIFY (10) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (2Eh) 

1 

WRPROTECT DPO Reserved BYTCHK Obsolete 

2 

(MSB) LOGICAL BLOCK ADDRESS 

5 

(LSB) 

6 

Reserved GROUP NUMBER 

7 

(MSB) TRANSFER LENGTH 

8 

(LSB) 

9 

CONTROL 


See clause 2.1.4 for the definition of the LOGICAL BLOCK ADDRESS field. See clause 2.1.4 for the definition 
of the GROUP NUMBER field. See the WRITE (10) command (see 3.54) for the definitions of the TRANSFER 
LENGTH field and the WRPROTECT field. See the READ (10) command (see 3.20) for the definition of the 
DPO bit. 

If the Verify Error Recovery mode page is also implemented, then the current settings in that mode page along 
with the AWRE bit in the Read-Write Error Recovery mode page specify the verification error criteria. If these 
mode pages are not implemented, then the verification criteria is vendor-specific. 

BYTCHK bit 

0 A byte check (BYTCHK) bit set to zero specifies that, after writing, the device server perform a medium verification 
with no data comparison. 

1 A BYTCHK bit set to one specifies that, after writing, the device server perform a byte-by-byte comparison of data 
written on the medium with the data just written. If the comparison is unsuccessful for any reason, the device server 
shall terminate the command with CHECK CONDITION status with the sense key set to MISCOMPARE and the 
additional sense code set to the appropriate value for the condition. 
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3.59 


WRITE AND VERIFY (12) command 


The WRITE AND VERIFY (12) command (see table 161) requests that the device server transfer the specified 
logical block(s) from the data-out buffer, write them to the medium, and then verify that they are correctly writ¬ 
ten. Each logical block includes user data and may include protection information, based on the WRPROTECT 
field and the medium format. The logical blocks are only transferred once from the data-out buffer to the device 
server. 

If the RTO_EN bit is set to one in the READ CAPACITY (16) parameter data (see 3.27), the device server shall 
terminate this command with CPIECK CONDITION status with the sense key set to ILLEGAL REQUEST and 
the additional sense code set to INVALID COMMAND OPERATION CODE. 


Table 161 — WRITE AND VERIFY (12) command 


Bit 

Byte 

7 

6 5 

4 3 2 1 0 

0 

OPERATION CODE (AEh) 

1 

WRPROTECT DPO Reserved BYTCHK Obsolete 

2 

(MSB) 


LOGICAL BLOCK ADDRESS 

5 


(LSB) 

6 

(MSB) 


TRANSFER LENGTH 

9 


(LSB) 

10 

Restricted 
for MMC-4 

Reserved 

GROUP NUMBER 

11 

CONTROL 


See the WRITE AND VERIFY (10) command (see 3.58) for the definitions of the fields in this command. 
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3.60 


WRITE AND VERIFY (16) command 


The WRITE AND VERIFY (16) command (see table 162) requests that the device server transfer the specified 
logical block(s) from the data-out buffer, write them to the medium, and then verify that they are correctly writ¬ 
ten. Each logical block includes user data and may include protection information, based on the WRPROTECT 
field and the medium format. The logical blocks are only transferred once from the data-out buffer to the device 
server. 

If the RTO_EN bit is set to one in the READ CAPACITY (16) parameter data (see 3.27), the device server shall 
terminate this command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and 
the additional sense code set to INVALID COMMAND OPERATION CODE 


Table 162 — WRITE AND VERIFY (16) command 


Bit 

Byte 

7 

6 5 

4 3 2 1 0 

0 

OPERATION CODE (8Eh) 

1 

WRPROTECT DPO Reserved BYTCHK Reserved 

2 

(MSB) 


LOGICAL BLOCK ADDRESS 

9 


(LSB) 

10 

(MSB) 


TRANSFER LENGTH 

13 


(LSB) 

14 

RESTRICTE 

D FOR MMC- 
4 

Reserved 

GROUP NUMBER 

15 

CONTROL 


See the WRITE AND VERIFY (10) command (see 3.58) for the definitions of the fields in this command. 
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3.61 WRITE AND VERIFY (32) command 

The WRITE AND VERIFY (32) command (see table 163) requests that the device server transfer the specified 
logical block(s) from the data-out buffer, write them to the medium, and then verify that they are correctly writ¬ 
ten. Each logical block includes user data and may include protection information, based on the WRPROTECT 
field and the medium format. The logical blocks are only transferred once from the data-out buffer to the device 
server. 

If the RTO_EN bit is set to zero in the READ CAPACITY (16) parameter data (see 3.26), the device server shall 
terminate the command with CPIECK CONDITION status with the sense key set to ILLEGAL REQUEST and 
the additional sense code set to INVALID COMMAND OPERATION CODE. If the RTO_EN bit is set to one, the 
device server may process the command. 


Table 163 — WRITE AND VERIFY (32) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (7Fh) 

1 

CONTROL 

2 

Reserved 

5 


6 

Reserved GROUP NUMBER 

7 

ADDITIONAL CDB LENGTH (18h) 

8 

(MSB) SERVICE ACTION (OOOCh) 

9 

(LSB) 

10 

WRPROTECT DPO Reserved BYTCHK Reserved 

11 

Reserved 

12 

(MSB) LOGICAL BLOCK ADDRESS 

19 

(LSB) 

20 

(MSB) EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG 

23 

(LSB) 

24 

(MSB) EXPECTED LOGICAL BLOCK APPLICATION TAG 

25 

(LSB) 

26 

(MSB) LOGICAL BLOCK APPLICATION TAG MASK 

27 

(LSB) 

28 

(MSB) TRANSFER LENGTH 

31 

(LSB) 


See the WRITE AND VERIFY (10) command (see 3.58) for the definitions of the GROUP NUMBER field, the 
WRPROTECT field, the DPO bit, the BYTCHK bit, the LOGICAL BLOCK ADDRESS field, and the TRANSFER 
LENGTH field. 
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When checking of the LOGICAL BLOCK REFERENCE TAG field is enabled (see table 155), the EXPECTED 
INITIAL LOGICAL BLOCK REFERENCE TAG field contains the value of the LOGICAL BLOCK REFERENCE 
TAG field expected in the protection information of the first logical block accessed by the command instead of 
a value based on the LBA. 

If the ATO bit is set to one in the Control mode page (see SPC-4) and checking of the LOGICAL BLOCK 
APPLICATION TAG field is enabled (see table 155), the LOGICAL BLOCK APPLICATION TAG MASK field 
contains a value that is a bit mask for enabling the checking of the LOGICAL BLOCK APPLICATION TAG field 
in the protection information for each logical block accessed by the command. A LOGICAL BLOCK APPLICA¬ 
TION TAG MASK bit set to one enables the checking of the corresponding bit of the EXPECTED LOGICAL 
BLOCK APPLICATION TAG field with the corresponding bit of the LOGICAL BLOCK APPLICATION TAG field 
in the protection information. 

If the ATO bit is set to one in the Control mode page (see SPC-4) and checking of the LOGICAL BLOCK 
APPLICATION TAG field is disabled (see table 155), or if the ATO bit is set to zero, the LOGICAL BLOCK 
APPLICATION TAG MASK field and the EXPECTED LOGICAL BLOCK APPLICATION TAG field shall be 
ignored. 
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3.62 


WRITE BUFFER command 


3.62.1 WRITE BUFFER command introduction 

The WRITE BUFFER command (see table 164) is used in conjunction with the READ BUFFER command as a 
diagnostic function for testing logical unit memory in the SCSI target device and the integrity of the service 
delivery subsystem. Additional modes are provided for: 

a) Downloading microcode; 

b) Downloading and saving microcode; and 

c) Downloading application logs (see SPC-4 clause 5.12). 

Table 164 — WRITE BUFFER command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (3Bh) 

1 

Reserved MODE 

2 

BUFFER ID 

3 

(MSB) BUFFER OFFSET 

4 

(LSB) 

5 

(MSB) PARAMETER LIST LENGTH 

6 

(LSB) 

7 

CONTROL 


This command shall not alter any medium of the logical unit when the data mode or the combined header and 
data mode is specified. 

The function of this command and the meaning of fields within the CDB depend on the contents of the mode 
field. The MODE field is defined in table 165. 

Table 165 — WRITE BUFFER MODE field (Sheet 1 of 2) 


Mode 

Description 

OOh 

Write combined header and data a 

01 h 

Vendor specific a 

02h 

Write data 

04h 

Download microcode 

05h 

Download microcode and save 

06h 

Download microcode with offsets b 

07h 

Download microcode with offsets and save b 

OAh 

Echo buffer 

1 Ah 

Enable expander communications protocol and Echo buffer 

a Modes OOh and 01 h are not recommended. 

b When downloading microcode with buffer offsets, the WRITE BUFFER command mode should be 06h or 07h. 
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Table 165 — WRITE BUFFER MODE field (Sheet 2 of 2) 


Mode 

Description 

IBh 

Disable expander communications protocol 

ICh 

Download application log 

03h 

Reserved 

08h - 09h 

Reserved 

OBh-19h 

Reserved 

IDh-IFh 

Reserved 

a Modes OOh and 01 h are not recommended. 

b When downloading microcode with buffer offsets, the WRITE BUFFER command mode should be 06h or 07h. 


3.62.2 Combined header and data mode (OOh) 

In this mode, data to be transferred is preceded by a four-byte header. The four-byte header consists of all 
reserved bytes. The BUFFER ID and the BUFFER OFFSET fields shall be zero. The PARAMETER LIST 
LENGTH field specifies the maximum number of bytes that shall be transferred from the Data-Out Buffer. This 
number includes four bytes of header, so the data length to be stored in the device server’s buffer is parameter 
list length minus four. The application client should attempt to ensure that the parameter list length is not 
greater than four plus the BUFFER CAPACITY field value (see Table 94 —) that is returned in the header of 
the READ BUFFER command (mode Oh). If the parameter list length exceeds the buffer capacity, the com¬ 
mand shall be terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and 
the additional sense code set to INVALID FIELD IN CDB. 

3.62.3 Vendor specific mode (01 h) 

In this mode, the meaning of the BUFFER ID, BUFFER OFFSET, and PARAMETER LIST LENGTH fields are 
not specified by this manual or by SPC-4. 

3.62.4 Data mode (02h) 

In this mode, the Data-Out Buffer contains buffer data destined for the logical unit. The buffer id field identifies 
a specific buffer within the logical unit. Seagate assigns buffer ID codes to buffers within the logical unit. Buffer 
ID zero shall be supported. If more than one buffer is supported, then additional buffer ID codes shall be 
assigned contiguously, beginning with one. If an unsupported buffer ID code is selected, the command shall be 
terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional 
sense code set to INVALID FIELD IN CDB. 

Data are written to the logical unit buffer starting at the location specified by the buffer offset field. The appli¬ 
cation client should conform to the offset boundary requirements returned in the READ BUFFER descriptor. If 
the device server is unable to accept the specified buffer offset, the command shall be terminated with CHECK 
CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to 
INVALID FIELD IN CDB. 

The PARAMETER LIST LENGTH field specifies the maximum number of bytes that shall be transferred from 
the Data-Out Buffer to be stored in the specified buffer beginning at the buffer offset. The application client 
should attempt to ensure that the parameter list length plus the buffer offset does not exceed the capacity of 
the specified buffer. The capacity of the buffer is indicated by the BUFFER CAPACITY field in the READ 
BUFFER descriptor (see Table 94 —). If the BUFFER OFFSET and PARAMETER LIST LENGTH fields specify 
a transfer in excess of the buffer capacity, the command shall be terminated with CHECK CONDITION status, 
with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 
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3.62.5 


Download microcode mode (04h) 


In this mode, vendor specific microcode or control information shall be transferred to the control memory space 
of the logical unit. After a hard reset, the device operation shall revert to a vendor specific condition. The mean¬ 
ings of the BUFFER ID, BUFFER OFFSET, and PARAMETER LIST LENGTH fields are not specified by this 
standard and are not required to be zero-filled. When the microcode download has completed successfully the 
device server shall establish a unit attention condition (see SAM-3) for the initiator port associated with every 
l_T nexus except the l_T nexus on which the WRITE BUFFER command was received, with the additional 
sense code set to MICROCODE HAS BEEN CHANGED. 

If the logical unit is unable to accept this command because of some device condition, each WRITE BUFFER 
command with this mode (04h) shall be terminated with CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST, and the additional sense code set to COMMAND SEQUENCE ERROR. 

3.62.6 Download microcode and save mode (05h) 

In this mode, vendor specific microcode or control information shall be transferred to the logical unit and, if the 
WRITE BUFFER command is completed successfully, also shall be saved in a nonvolatile memory space (e.g., 
semiconductor, disk, or other). The downloaded code shall then be effective after each hard reset until it is sup¬ 
planted in another download microcode and save operation or download microcode with offsets and save 
operation. The meanings of the BUFFER ID, BUFFER OFFSET, and PARAMETER LIST LENGTH fields are 
not specified by this standard and are not required to be zero-filled. When the download microcode and save 
command has completed successfully the device server shall establish a unit attention condition (see SAM-3) 
for the initiator port associated with every l_T nexus except the l_T nexus on which the WRITE BUFFER com¬ 
mand was received with the additional sense code set to MICROCODE HAS BEEN CHANGED. 

If the logical unit is unable to accept this command because of some device condition, each WRITE BUFFER 
command with this mode (05h) shall be terminated with CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST, and the additional sense code set to COMMAND SEQUENCE ERROR. 

3.62.7 Download microcode with offsets mode (06h) 

In this mode, the application client may split the transfer of Seagate specific microcode or control information 
over two or more WRITE BUFFER commands. If the last WRITE BUFFER command of a set of one or more 
commands completes successfully, then the microcode or control information shall be transferred to the control 
memory space of the logical unit. After a hard reset, the device shall revert to a vendor specific condition. In 
this mode, the Data-Out Buffer contains vendor specific, self-describing microcode or control information. 

Since the downloaded microcode or control information may be sent using several commands, when the logi¬ 
cal unit detects the last download microcode with offsets WRITE BUFFER command has been received, the 
device server shall perform any logical unit required verification of the complete set of downloaded microcode 
or control information prior to returning GOOD status for the last command. After the last command completes 
successfully the device server shall establish a unit attention condition (see SAM-3) for the initiator port associ¬ 
ated with every l_T nexus except the l_T nexus on which the set of WRITE BUFFER commands was received, 
with the additional sense code set to MICROCODE HAS BEEN CHANGED. 

If the complete set of WRITE BUFFER commands required to effect a microcode or control information change 
(i.e., one or more commands) are not received before a logical unit reset or l_T nexus loss occurs, the change 
shall not be effective and the new microcode or control information shall be discarded. 

The BUFFER ID field specifies a buffer within the logical unit. Seagate assigns buffer ID codes to buffers within 
the logical unit. A buffer ID value of zero shall be supported. If more than one buffer is supported, then addi¬ 
tional buffer ID codes shall be assigned contiguously, beginning with one. If an unsupported buffer ID code is 
specified, the command shall be terminated with CHECK CONDITION status, with the sense key set to ILLE¬ 
GAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 
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The microcode or control information are written to the logical unit buffer starting at the location specified by the 
BUFFER OFFSET field. The application client shall send commands that conform to the offset boundary 
requirements. If the device server is unable to accept the specified buffer offset, the command shall be termi¬ 
nated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional 
sense code set to INVALID FIELD IN CDB. 

The PARAMETER LIST LENGTH field specifies the maximum number of bytes that shall be present in the 
Data-Out Buffer to be stored in the specified buffer beginning at the buffer offset. The application client should 
ensure that the parameter list length plus the buffer offset does not exceed the capacity of the specified buffer. 
The capacity of the buffer is indicated by the BUFFER CAPACITY field in the READ BUFFER descriptor (see 
Table 94 —). If the BUFFER OFFSET and PARAMETER LIST LENGTH fields specify a transfer in excess of 
the buffer capacity, then the command shall be terminated with CHECK CONDITION status, with the sense key 
set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 

If the logical unit is unable to accept this command because of some device condition, each WRITE BUFFER 
command with this mode (06h) shall be terminated with CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST, and the additional sense code set to COMMAND SEQUENCE ERROR. 

3.62.8 Download microcode with offsets and save mode (07h) 

In this mode, the application client may split the transfer of Seagate specific microcode or control information 
over two or more WRITE BUFFER commands. If the last WRITE BUFFER command of a set of one or more 
commands completes successfully, then the microcode or control information shall be saved in a nonvolatile 
memory space (e.g., semiconductor, disk, or other). The saved downloaded microcode or control information 
shall then be effective after each hard reset until it is supplanted by another download microcode with save 
operation or download microcode with offsets and save operation. In this mode, the Data-Out Buffer contains 
vendor specific, self-describing microcode or control information. 

Since the downloaded microcode or control information may be sent using several commands, when the logi¬ 
cal unit detects the last download microcode with offsets and save mode WRITE BUFFER command has been 
received, the device server shall perform any logical unit required verification of the complete set of down¬ 
loaded microcode or control information prior to returning GOOD status for the last command. After the last 
command completes successfully the device server shall establish a unit attention condition (see SAM-3) for 
the initiator port associated with every l_T nexus except the l_T nexus on which the set of WRITE BUFFER 
commands was received, with the additional sense code set to MICROCODE HAS BEEN CHANGED. 

If the complete set of WRITE BUFFER commands required to effect a microcode or control information change 
(i.e., one or more commands) are not received before a logical unit reset or l_T nexus loss occurs, the change 
shall not be effective and the new microcode or control information shall be discarded. 

The BUFFER ID field specifies a buffer within the logical unit. Seagate assigns buffer ID codes to buffers within 
the logical unit. A buffer ID value of zero shall be supported. If more than one buffer is supported, then addi¬ 
tional buffer ID codes shall be assigned contiguously, beginning with one. If an unsupported buffer ID code is 
specified, the command shall be terminated with CHECK CONDITION status, with the sense key set to ILLE¬ 
GAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 

The microcode or control information are written to the logical unit buffer starting at the location specified by the 
BUFFER OFFSET field. The application client shall conform to the offset boundary requirements. If the device 
server is unable to accept the specified buffer offset, the command shall be terminated with CHECK CONDI¬ 
TION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID 
FIELD IN CDB. 

The PARAMETER LIST LENGTH field specifies the maximum number of bytes that shall be present in the 
Data-Out Buffer to be stored in the specified buffer beginning at the buffer offset. The application client should 
ensure that the parameter list length plus the buffer offset does not exceed the capacity of the specified buffer. 
The capacity of the buffer is indicated by the BUFFER CAPACITY field in the READ BUFFER descriptor (see 
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Table 94 —)■ If the BUFFER OFFSET and PARAMETER LIST LENGTH fields specify a transfer in excess of 
the buffer capacity, then the command shall be terminated with CHECK CONDITION status, with the sense key 
set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN CDB. 

If the logical unit is unable to accept this command because of some device condition, each WRITE BUFFER 
command with this mode (07h) shall be terminated with CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST, and the additional sense code set to COMMAND SEQUENCE ERROR. 

3.62.9 Write data to echo buffer mode (OAh) 

In this mode the device server transfers data from the application client and stores it in an echo buffer. An echo 
buffer is assigned in the same manner by the device server as it would for a write operation. Data shall be sent 
aligned on four-byte boundaries. The BUFFER ID and BUFFER OFFSET fields are ignored in this mode. 

Note. It is recommended that the logical unit assign echo buffers on a per l_T nexus basis to limit the 
number of exception conditions that may occur when l_T nexuses are present. 

Upon successful completion of a WRITE BUFFER command the data shall be preserved in the echo buffer 
unless there is an intervening command to any logical unit in which case the data may be changed. 

The PARAMETER LIST LENGTH field specifies the maximum number of bytes that shall be transferred from 
the Data-Out Buffer to be stored in the echo buffer. The application client should ensure that the parameter list 
length does not exceed the capacity of the echo buffer. The capacity of the echo buffer is indicated by the 
BUFFER CAPACITY field in the READ BUFFER echo buffer descriptor (see Table 96 —). If the PARAMETER 
LIST LENGTH field specifies a transfer in excess of the buffer capacity, the command shall be terminated with 
CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set 
to INVALID FIELD IN CDB. 

3.62.10 Enable expander communications protocol and Echo buffer mode (1Ah) 

Receipt of a WRITE BUFFER command with this mode (1Ah) causes a communicative expander (see SPI-5) 
to enter the expanded communications protocol mode. Device servers in SCSI target devices that receive a 
WRITE BUFFER command with this mode shall process it as if it were a WRITE BUFFER command with 
mode OAh (see 3.62.9). 

3.62.11 Disable expander communications protocol mode (IBh) 

Receipt of a WRITE BUFFER command with this mode (IBh) causes a communicative expander (see SPI-5) 
to exit the expanded communications protocol mode and return to simple expander operation. Device servers 
in SCSI target devices that receive a WRITE BUFFER command with this mode shall terminate the command 
with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code 
set to INVALID FIELD IN CDB. 

3.62.12 Download application log mode (ICh) 

In this mode the device server transfers data from the application client and stores it in an application log. The 
format of the application log data is as specified in table 166. The BUFFER ID field and BUFFER OFFSET field 
are ignored in this mode. 

Upon successful completion of a WRITE BUFFER command the data shall be appended to the application log. 
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The PARAMETER LIST LENGTH field specifies the maximum number of bytes that shall be transferred from 
the Data-Out Buffer to be stored in the application log. If the PARAMETER LIST LENGTH field specifies a 
transfer that exceeds the application log’s capacity, the command shall be terminated with CHECK CONDI¬ 
TION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID 
FIELD IN CDB. 


Table 166 — Application log data WRITE BUFFER format 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

(MSB) T10 VENDOR IDENTIFICATION 

7 

(LSB) 

8 

(MSB) ERROR TYPE 

9 

(LSB) 

10 

Reserved 

11 


12 

(MSB) TIME STAMP 

17 

(LSB) 

18 

Reserved 

19 


20 

Reserved CODE SET 

21 

ERROR LOCATION FORMAT 

22 

(MSB) ERROR LOCATION LENGTH (M-25) 

23 

(LSB) 

24 

(MSB) VENDOR SPECIFIC LENGTH (N-M) 

25 

(LSB) 

26 

(MSB) ERROR LOCATION 

m 

(LSB) 

m+1 

Vendor specific 

n 



The Tl 0 VENDOR IDENTIFICATION field contains eight bytes of left-aligned ASCII data identifying the vendor 
of the product. The T10 vendor identification shall be one assigned by INCITS. A list of assigned T10 vendor 
identifications is in SPC-4 Annex E and on the T10 web site (http://www.T10.org). 
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The ERROR TYPE field (see table 167) specifies the error detected by the application client. 

Table 167 — ERROR TYPE field 


Code 

Description 

OOOOh 

No error specified by the application client 

0001 h 

An unknown error was detected by the application client 

0002h 

The application client detected corrupted data 

0003h 

The application client detected a permanent error 

0004h 

The application client detected a service response of SERVICE DELIVERY OR TARGET FAIL¬ 
URE (SAM-3). 

0005h - 7FFFh 

Reserved 

8000h - FFFFh 

Vendor specific 


The TIME STAMP field shall contain: 

a) The number of milliseconds that have elapsed since midnight, 1 January 1970 UT; or 

b) Zero, if the application client is not able to determine the UT of the log entry. 

The CODE SET field specifies the code set used for the application log information (see table 168) and shall 
only apply to information contained in the VENDOR SPECIFIC field. 

Note. The CODE SET field is intended to be an aid to software that displays the application log informa¬ 
tion. 

Table 168 — CODE SET field 


Code 

Description 

Oh 

Reserved 

1h 

The application log information is binary 

2h 

The application log information is ASCII printable characters (i.e., code values 20h through 7Eh) 

3h 

The application log information is ISO/IEC 10646-1 (UTF-8) codes 

4h - Fh 

Reserved 

The ERROR LOCATION FORMAT field specifies the format (see table 169) of the ERROR LOCATION field. 

Table 169- 

- ERROR LOCATION FORMAT field 

Code 

Description 

OOh 

No error specified by the application client 

Olh 

The error location field specifies the logical block (e.g., LBA) associated with the error information con¬ 
tained within the application log. 

02h - 7Fh 

Reserved 

80h - FFh 

Vendor specific 


The ERROR LOCATION LENGTH field specifies the length of the ERROR LOCATION field. The ERROR 
LOCATION LENGTH field value shall be a multiple of four. An error location length value of zero specifies 
there is no error location information. 
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The VENDOR SPECIFIC LENGTH field specifies the length of the VENDOR SPECIFIC field. The VENDOR 
SPECIFIC LENGTH field value shall be a multiple of four. A vendor specific length value of zero specifies there 
is no vendor specific information. 

The ERROR LOCATION field specifies the location at which the application client detected the error. 

The VENDOR SPECIFIC field provides vendor specific information on the error. 
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3.63 


WRITE LONG (10) command 


The WRITE LONG (10) command (see table 170) requests that the device server transfer data for a single log¬ 
ical block from the data-out buffer and write it to the medium. The data written shall be the same length and 
shall be in the same order as the data returned by the READ LONG (10) command (see 3.29). The device 
server shall write the logical block to the medium, and shall not return GOOD status until the logical block has 
actually been written on the medium. 


Table 170 — WRITE LONG (10) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (3Fh) 

1 

Reserved Obsolete 

2 

(MSB) LOGICAL BLOCK ADDRESS 

5 

(LSB) 

6 

Reserved 

7 

(MSB) BYTE TRANSFER LENGTH 

8 

(LSB) 

9 

CONTROL 


LOGICAL BLOCK ADDRESS field 

See clause 2.1.4 for the definition of the LOGICAL BLOCK ADDRESS field. 

BYTE TRANSFER LENGTH field 

The BYTE TRANSFER LENGTH field specifies the number of bytes of data that the device server shall transfer from the 
data-out buffer and write to the specified logical block. If the BYTE TRANSFER LENGTH field is not set to zero and does 
not match the data length that the device server returns for a READ LONG command, then the device server shall termi¬ 
nate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the additional 
sense code set to INVALID FIELD IN CDB. In the sense data (see SPC-4), the ILI and VALID bits shall be set to one and 
the INFORMATION field shall be set to the difference (i.e., residue) of the requested length minus the actual length in 
bytes. Negative values shall be indicated by two's complement notation. A BYTE TRANSFER LENGTH field set to zero 
specifies that no bytes shall be written. This condition shall not be considered an error. 
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3.64 


WRITE LONG (16) command 


The WRITE LONG (16) command (see table 171) requests that the device server transfer data for a single log¬ 
ical block from the data-out buffer and write it to the medium. The data written shall be the same length and 
shall be in the same order as the data returned by the READ LONG (16) command (see 3.30). The device 
server shall write the logical block to the medium, and shall not return GOOD status until the logical block has 
actually been written on the medium. This command is implemented as a service action of the SERVICE 
ACTION OUT operation code. 


Table 171 — WRITE LONG (16) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (9Fh) 

1 

Reserved SERVICE ACTION (11 h) 

2 

(MSB) LOGICAL BLOCK ADDRESS 

9 

(LSB) 

10 

Reserved 

11 


12 

(MSB) BYTE TRANSFER LENGTH 

13 

(LSB) 

14 

Reserved CORRCT 

15 

CONTROL 


See the WRITE LONG (10) command (see 3.63) for the definitions of the fields in this command. 
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3.65 WRITE SAME (10) command 

The WRITE SAME (10) command (see table 172) requests that the device server transfer a single logical block 
from the data-out buffer and write the contents of that logical block, with modifications based on the lbdata bit 
and the pbdata bit, to the specified range of logical block addresses. Each logical block includes user data and 
may include protection information, based on the WRPROTECT field and the medium format. 

If the RTO_EN bit is set to one in the READ CAPACITY (16) parameter data (see 3.27), the device server shall 
terminate this command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and 
the additional sense code set to INVALID COMMAND OPERATION CODE. 

Note. This command may be useful if large areas of the medium need to be written, prepared for certifica¬ 
tion, or otherwise initialized without having to transfer all the data. 

Table 172 — WRITE SAME (10) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (41 h) 

1 

WRPROTECT Reserved PBDATA LBDATA Obsolete 

2 

(MSB) LOGICAL BLOCK ADDRESS 

5 

(LSB) 

6 

Reserved GROUP NUMBER 

7 

(MSB) NUMBER OF BLOCKS 

8 

(LSB) 

9 

CONTROL 


WRPROTECT field 

See the WRITE (10) command (see 3.54) for the definitions of the WRPROTECT field. 

LOGICAL BLOCK ADDRESS field 

See clause 2.1.4 for the definition of the LOGICAL BLOCK ADDRESS field. 

GROUP NUMBER field 

See clause 2.1.4 for the definition of the GROUP NUMBER field. 
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Table 173 describes the LBDATA bit and the PBDATA bit. 


Table 173 — LBDATA bit and PBDATA bit 


LBDATA 

PBDATA 

Description 



The device server shall write the single block of user data received from the data-out buffer to 
each logical block without modification. 

0 

0 

If the medium is formatted with protection information: 

a the value in the LOGICAL BLOCK REFERENCE TAG field received in the single block of 
data from the data-out buffer shall be placed into the LOGICAL BLOCK REFERENCE 
TAG field of the first logical block written to the medium. Into each of the subsequent 
logical blocks, the device server shall place into the LOGICAL BLOCK REFERENCE 

TAG field the value of the previous logical block’s LOGICAL BLOCK REFERENCE TAG 
field plus one; 

b If the ATO bit is set to one in the Control mode page (see SPC-4), the logical block 
application tag received in the single block of data shall be placed in the LOGICAL 

BLOCK APPLICATION TAG field of each logical block. If the ATO bit is set to zero, the 
device server may write any value into the LOGICAL BLOCK APPLICATION TAG field of 
each logical block; and 

c The value in the DATA BLOCK GUARD field received in the single block of data from the 
data-out buffer shall be placed in the DATA BLOCK GUARD field of each logical block. 

0 

1 a 

The device server shall replace the first eight bytes of the block received from the data-out 
buffer to each physical sector with the physical address of the sector being written using the 
physical sector format (see 3.5.5.5). 

1 a 

0 

The device server shall replace the first four bytes of the block received from the data-out 
buffer with the least significant four bytes of the LBA of the block being written, ending with the 
least significant byte (e.g., if the LBA is 77665544_33221100h, 33221100h is written with 33h 
written first and OOh written last). 

1 

1 

The device server shall terminate the command with CHECK CONDITION status with the 
sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN 
CDB. 

a If the medium is formatted with protection information then the protection information shall be written to a default value 
of FFFFFFFF_FFFFFFFFh in each of the written logical blocks. 


The NUMBER OF BLOCKS field specifies the number of contiguous logical blocks to be written, starting with 
the logical block specified by the LOGICAL BLOCK ADDRESS field. A NUMBER OF BLOCKS field set to zero 
specifies that the device server write all the logical blocks starting with the one specified in the LOGICAL 
BLOCK ADDRESS field to the last logical block on the medium. If the logical block address plus the number of 
blocks exceeds the capacity of the medium, the device server shall terminate the command with CHECK 
CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to 
LOGICAL BLOCK ADDRESS OUT OF RANGE. 
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3.66 


WRITE SAME (16) command 


The WRITE SAME (16) command (see table 174) requests that the device server transfer a single logical block 
from the data-out buffer and write the contents of that logical block, with modifications based on the lbdata bit 
and the pbdata bit, to the specified range of logical block addresses. Each logical block includes user data and 
may include protection information, based on the WRPROTECT field and the medium format. 

If the RTO_EN bit is set to one in the READ CAPACITY (16) parameter data (see 3.27), the device server shall 
terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and 
the additional sense code set to INVALID COMMAND OPERATION CODE 


Table 174 — WRITE SAME (16) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (93h) 

1 

WRPROTECT Reserved PBDATA LBDATA Reserved 

2 

(MSB) LOGICAL BLOCK ADDRESS 

9 

(LSB) 

10 

(MSB) NUMBER OF BLOCKS 

13 

(LSB) 

14 

Reserved GROUP NUMBER 

15 

CONTROL 


See the WRITE SAME (10) command (see 3.65) for the definitions of the fields in this command. 
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3.67 


WRITE SAME (32) command 


The WRITE SAME (32) command (see table 175) requests that the device server transfer a single logical block 
from the data-out buffer and write the contents of that logical block, with modifications based on the lbdata bit 
and the pbdata bit, to the specified range of logical block addresses. Each logical block includes user data and 
may include protection information, based on the WRPROTECT field and the medium format. 

If the RTO_EN bit is set to zero in the READ CAPACITY (16) parameter data (see 3.27), the device server shall 
terminate the command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and 
the additional sense code set to INVALID COMMAND OPERATION CODE. If the RTO_EN bit is set to one, the 
device server may process the command. 


Table 175 — WRITE SAME (32) command 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

OPERATION CODE (7Fh) 

1 

CONTROL 

2 

Reserved 

5 


6 

Reserved GROUP NUMBER 

7 

ADDITIONAL CDB LENGTH (18h) 

8 

(MSB) SERVICE ACTION (OOODh) 

9 

(LSB) 

10 

WRPROTECT Reserved PBDATA LBDATA Reserved 

11 

Reserved 

12 

(MSB) LOGICAL BLOCK ADDRESS 

19 

(LSB) 

20 

(MSB) EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG 

23 

(LSB) 

24 

(MSB) EXPECTED LOGICAL BLOCK APPLICATION TAG 

25 

(LSB) 

26 

(MSB) LOGICAL BLOCK APPLICATION TAG MASK 

27 

(LSB) 

28 

(MSB) NUMBER OF BLOCKS 

31 

(LSB) 


See the WRITE SAME (10) command (see 3.65) for the definitions of the GROUP NUMBER field, the 
WRPROTECT field, the PBDATA bit, the LBDATA bit, the LOGICAL BLOCK ADDRESS field, and the 
NUMBER OF BLOCKS field. 
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When checking of the LOGICAL BLOCK REFERENCE TAG field is enabled (see table 155 in 3.54), the 
EXPECTED INITIAL LOGICAL BLOCK REFERENCE TAG field contains the value of the LOGICAL BLOCK 
REFERENCE TAG field expected in the protection information of the first logical block accessed by the com¬ 
mand instead of a value based on the LBA (see 2.1.4). 

If the ATO bit is set to one in the Control mode page (see SPC-4) and checking of the LOGICAL BLOCK 
APPLICATION TAG field is enabled (see table 155 in 3.54), the LOGICAL BLOCK APPLICATION TAG MASK 
field contains a value that is a bit mask for enabling the checking of the LOGICAL BLOCK APPLICATION TAG 
field in the protection information for each logical block accessed by the command. A LOGICAL BLOCK 
APPLICATION TAG MASK bit set to one enables the checking of the corresponding bit of the EXPECTED 
LOGICAL BLOCK APPLICATION TAG field with the corresponding bit of the LOGICAL BLOCK APPLICATION 
TAG field in the protection information. 
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4.0 


Parameters for all device types 


This clause provides information on parameters for Disgnostic (Receive Diagnostic), Log (Sense), Mode 
(Sense), Protocol specific, and Vital product data (Inquiry) pages 
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4.1 


Diagnostic parameters 


4.1.1 Diagnostic page format and page codes for all device types 

This subclause describes the diagnostic page structure and the diagnostic pages that are applicable to all 
SCSI devices. Diagnostic pages specific to each device type are described in the command standard that 
applies to that device type. 

A SEND DIAGNOSTIC command with a PF bit set to one specifies that the SEND DIAGNOSTIC parameter list 
consists of a single diagnostic page and that the data returned by the subsequent RECEIVE DIAGNOSTIC 
RESULTS command that has the PCV bit set to zero shall use the diagnostic page format defined in table 176. 
A RECEIVE DIAGNOSTIC RESULTS command with a PCV bit set to one specifies that the device server 
return a diagnostic page using the format defined in table 176. 


Table 176 — Diagnostic page format 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

PAGE CODE 

1 

PAGE CODE SPECIFIC 

2 

(MSB) PAGE LENGTH (N-3) 

3 

(LSB) 

4 

DIAGNOSTIC PARAMETERS 

n 



Each diagnostic page defines a function or operation that the device server shall perform as a result of a SEND 
DIAGNOSTIC command or the information being returned as a result of a RECEIVE DIAGNOSTIC RESULTS 
command with the PCV bit equal to one. The diagnostic parameters contain data that is formatted according to 
the page code specified. 
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PAGE CODE field 

The PAGE CODE field identifies the diagnostic page (see table 177). 


Table 177 — Diagnostic page codes 


Page Code 

Diagnostic Page Name 

Reference 

OOh 

Supported Diagnostic Pages 

4.1.2 

01 h - 2Fh 

Defined by SES-2 for: 

a Enclosure services devices (i.e., SCSI devices with the PERIPHERAL 
DEVICE TYPE field set to ODh in standard INQUIRY data); and 
b SCSI devices with the ENCSERV bit set to one in standard INQUIRY data 
(see 3.6.2). 

Note. These pages are described in SES-2 these pages are passed 
along to any attached enclosure services device. 

SES-2 
clause 6.1 

30h - 3Eh 

Reserved 


3Fh 

See specific SCSI transport protocol for definition 


40h - 7Fh 

See specific device type for definition 


80h - FFh 

Vendor specific 



PAGE LENGTH field 

The PAGE LENGTH field contains the length in bytes of the diagnostic parameters that follow this field. If the application cli¬ 
ent sends a SEND DIAGNOSTIC command with a parameter list containing a PAGE LENGTH field that results in the trun¬ 
cation of any parameter, then the command shall be terminated with CHECK CONDITION status, with the sense key set to 
ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 

The diagnostic parameters are defined for each diagnostic page code. The diagnostic parameters within a diagnostic page 
may be defined differently in a SEND DIAGNOSTIC command than in a RECEIVE DIAGNOSTIC RESULTS command. 


4.1.2 Supported diagnostic pages (OOh) 

The Supported Diagnostic Pages diagnostic page (see table 178) returns the list of diagnostic pages imple¬ 
mented by the device server. This diagnostic page shall be implemented if the device server implements the 
diagnostic page format option of the SEND DIAGNOSTIC and RECEIVE DIAGNOSTIC RESULTS commands. 


Table 178 — Supported diagnostic pages 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

PAGE CODE (OOh) 

1 

Reserved 

2 

(MSB) PAGE LENGTH (N-3) 

3 

(LSB) 

4 

SUPPORTED PAGE LIST 

n 



The definition of this diagnostic page for the SEND DIAGNOSTIC command includes only the first four bytes. If 
the PAGE LENGTH field is not zero, the device server shall terminate the SEND DIAGNOSTIC command with 
CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set 
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to INVALID FIELD IN PARAMETER LIST. This diagnostic page instructs the device server to make available 
the list of all supported diagnostic pages to be returned by a subsequent RECEIVE DIAGNOSTIC RESULTS 
command. 

The definition of this diagnostic page for the RECEIVE DIAGNOSTIC RESULTS command includes the list of 
diagnostic pages supported by the device server. 

PAGE LENGTH field 

The PAGE LENGTH field specifies the length in bytes of the following supported page list. 

SUPPORTED PAGE LIST field 

The SUPPORTED PAGE LIST field shall contain a list of all diagnostic page codes, one per byte, implemented by the 
device server in ascending order beginning with page code OOh. 

4.1.3 Translate Address page (40h) 

The Translate Address page allows the initiator to translate a LOGICAL BLOCK ADDRESS into a physical sec¬ 
tor address or a physical sector address to a LOGICAL BLOCK ADDRESS. The address to be translated is 
passed to the target during the DATA OUT phase associated with the SEND DIAGNOSTIC command and the 
results are returned to the initiator during the DATA IN phase following the RECEIVE DIAGNOSTIC RESULTS 
command. The translated address is returned in the Translate Address page—Receive Diagnostic (Table 179). 


Table 179 — Translate Address page—Receive Diagnostic (40h) 


Bit 

Byte 

7 6 5 4 

3 2 10 

0 

PAGE CODE (40h) 

1 

Reserved 

2 

3 

(MSB) PAGE LENGTH (000A) or (0002) 

(LSB) 

4 

Reserved 

SUPPLIED FORMAT 

5 

RAREA ALTSEC ALTTK Reserved 

TRANSLATED FORMAT 

6 

13 

TRANSLATED ADDRESS (if available) 


PAGE CODE field 

The Translate Address page contains a four byte page header which specifies the page code and length followed by two 
bytes which describe the translated address followed by the translated address. 

PAGE LENGTH field 

The PAGE LENGTH field contains the number of parameter bytes which follow. 

SUPPLIED FORMAT field 

The SUPPLIED FORMAT field contains the value from the SEND DIAGNOSTIC command supplied format field (see Table 
179). 

RAREA (Reserved Area) bit 

1 A Reserved Area (RAREA) bit of one indicates that all or part of the translated address falls within a reserved area 
of the medium (e.g., speed tolerance gap, alternate logical block, vendor reserved area, etc.). If the entire translated 
address falls within a reserved area the target may not return a translated address. 
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0 An RAREA bit of zero indicates that no part of the translated address falls within a reserved area of the medium. 


Table 180 — Address Field Logical Block Address Format 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

3 

(MSB) 



LOGICAL BLOCK ADDRESS 




(LSB) 

4 

0 

0 

0 

0 

0 

0 

0 

0 

5 

0 

0 

0 

0 

0 

0 

0 

0 

6 

0 

0 

0 

0 

0 

0 

0 

0 

7 

0 

0 

0 

0 

0 

0 

0 

0 


Table 181 —Address Field Physical Sector Address Format 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

1 

2 

(MSB) 



CYLINDER NUMBER 





(LSB) 

3 

HEAD NUMBER 

4 




SECTOR NUMBER 




5 









6 









7 










ALTSEC (Alternate Sector) bit 

1 An Alternate Sector (ALTSEC) bit of one indicates that the translated address is physically located in an alternate 
sector of the medium. If the drive cannot determine if all or part of the translated address is located in an alternate 
sector it shall set this bit to zero. 

0 An ALTSEC bit of zero indicates that no part of the translated address is located in an alternate sector of the 
medium or that the drive is unable to determine this information. 

ALTTRK (Alternate Track) bit 

1 An Alternate Track (ALTTRK) bit of one indicates that part or all of the translated address is located on an alternate 
track of the medium or the drive cannot determine if all or part of the translated address is located on an alternate 
track. 

0 An ALTTRK bit of zero indicates that no part of the translated address is located on an alternate track of the 
medium. 

TRANSLATED FORMAT field 

The TRANSLATED FORMAT field contains the value from the SEND DIAGNOSTIC command translate format field (see 

Table 179). The values are 000 (Logical block format) or 101 (Physical sector address format). 
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TRANSLATED ADDRESS field 


The TRANSLATED ADDRESS field contains the address the target translated from the address supplied by the initiator in 
the SEND DIAGNOSTIC command. This field shall be in the format specified in the translate format field. The supported 
formats are shown in Tables 180 and 181. 

4.1.4 SCSI Enclosure Services pages (01 h - 2Fh) 

When the drive supports the SCSI Enclosure Service (SES) pages, it does not process the contents of the 
pages. The drive attempts to transfer the page contents to the enclosure using the Enclosure Services Inter¬ 
face (ESI) as directed by the command. Errors detected in the transfer are returned to the initiator in response 
to the command. See SCSI-3 Enclosure Services -2 (SES-2) for descriptions of the data presented in the SES 
pages. Reference the drive product manual to determine if the SES pages are supported. 


Table 182 — SCSI Enclosure Services page 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

PAGE CODE (01 h - 2Fh) 

1 

Page Specific 

2 

3 

(MSB) PAGE LENGTH (n - 3) 

(LSB) 

n 

Page Specific 


The PAGE CODE 01 h - 2Fh SCSI Enclosure Services (SES) pages. 

The Page Specific field is defined in the SCSI-3 Enclosure Services - 2 (SES-2) standard. 
Page Length (n - 3). 
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4.2 


Log parameters 


4.2.1 Log page structure and page codes for all device types 

This subclause describes the log page structure and the log pages that are applicable to all SCSI devices. Log 
pages specific to each device type are described in the command standard that applies to that device type. 
The LOG SELECT command (see 3.9) supports the ability to send zero or more log pages. The LOG SENSE 
command (see 3.10) returns a single log page specified in the PAGE CODE field of the CDB. 

Each log page begins with a four-byte page header followed by zero or more variable-length log parameters 
defined for that log page. The log page format is defined in table 183. 


Table 183 — Log page format 


Bit 

Byte 

7 6 

5 4 3 2 1 0 

0 

Reserved 

PAGE CODE 

1 

Reserved 

2 

(MSB) PAGE LENGTH (n-3) 

3 

(LSB) 


Log parameter(s) 

4 

Log parameter (First) 

x+3 

(Length x) 



n-y+1 

Log parameter (Last) 

n 

(Length y) 


PAGE CODE field 

The value in the PAGE CODE field is the number of the log page is being transferred. 

PAGE LENGTH field 

The value in the PAGE LENGTH field is the length in bytes of the following log parameters. If the application 
client sends a log page length that results in the truncation of any parameter, the command shall be terminated 
with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code 
set to INVALID FIELD IN PARAMETER LIST. 
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Most log pages contain one or more special data structures called log parameters (see table 184). Log param¬ 
eters may be data counters of a particular event(s), the conditions under which certain operations were per¬ 
formed, or list parameters that contain a character string description of a particular event. 

Table 184 — Log parameter 


Bit 

Byte 

7 

6 5 4 3 2 1 

0 

0 

(MSB) 

PARAMETER CODE 


1 


(LSB) 

2 

DU 

DS TSD ETC TMC LBIN 

LP 

3 

PARAMETER LENGTH (N-3) 

4 


PARAMETER VALUE 


n 




Each log parameter begins with a four-byte parameter header followed by one or more bytes of PARAMETER 
VALUE data. 

PARAMETER CODE field 

The PARAMETER CODE field identifies the log parameter being transferred for that log page. These codes are listed 
and explained in the individual page code descriptions following Table 186. 

Byte 2 - Parameter Control byte 

The DU bit, DS bit, TSD bit, ETC bit, TMC field, LBIN bit, and LP bit are collectively referred to as the parame¬ 
ter control byte. These fields are described in this subclause. 

DU (Disable Update) bit 

For cumulative log parameter values, indicated by the PC field of the LOG SELECT and LOG SENSE commands, the dis¬ 
able update (DU) bit is defined as follows: 

0 DU set to zero indicates that the device server shall update the log parameter value to reflect all events that should 
be noted by that parameter; or 

1 DU set to one indicates that the device server shall not update the log parameter value except in response to a LOG 
SELECT command that specifies a new value for the parameter. 

Note. When updating cumulative log parameter values, a device server may use volatile memory to hold these values 
until a LOG SELECT or LOG SENSE command is received with an SP bit set to one or a vendor specific event 
occurs. As a result the updated cumulative log parameter values may be lost if a power cycle occurs. 

The DU flag is set to one when the current cumulative value of the parameter counter it controls reaches its maximum value 
(see PARAMETER LENGTH field). Upon reaching this maximum value, the data counter does not wrap around and start 
over at zero. Incrementing of other counters within the same log pages ceases. Counters do not restart automatically if the 
overflowed counter is re-initialized. If the data counter reaches its maximum value during the execution of a command, the 
drive completes the command. Drive counter updates are performed in the background. This means a counter may over¬ 
flow long after a command has completed, so the drive must treat this condition as a UNIT ATTENTION with the additional 
sense code set to Log Counter at max for all initiators if RLEC=1 (Report Log Exception Condition bit of the Control Mode 
Page OAh). 

The DU bit is not defined for threshold values, indicated by the PC field of the LOG SENSE command, or for list parameters 
as indicated by the LP bit. The device server shall ignore the value of the DU bit in any such log parameters received with a 
LOG SELECT command. 

DS (Disable Save) bit 

0 A disable save (DS) bit set to zero indicates that the logical unit supports saving for that log parameter. The device 
server shall save the current cumulative or the current threshold parameter value, depending on the value in the PC 
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field of the CDB, in response to a LOG SELECT or LOG SENSE command with an SP bit set to one. 

1 A DS bit set to one indicates that the logical unit does not support saving that log parameter in response to a LOG 
SELECT or LOG SENSE command with an SP bit set to one. 

TSD (Target Save Disable) bit 

0 A target save disable (TSD) bit set to zero indicates that the logical unit implicitly saves the log parameter at vendor 
specific intervals. This implicit saving operation shall be done frequently enough to insure that the cumulative 
parameter values retain statistical significance (i.e., across power cycles). 

1 A TSD bit set to one indicates that either the logical unit does not implicitly save the log parameter or implicit saving 
of the log parameter has been disabled individually by an application client setting the TSD bit to one. An application 
client may disable the implicit saving for all log parameters without changing any TSD bits using the GLTSD bit in 
the Control mode page. 

ETC (Enable Threshold Comparison) bit 

1 An enable threshold comparison (ETC) bit set to one indicates that a comparison to the threshold value is per¬ 
formed whenever the cumulative value is updated. 

0 An ETC bit set to zero indicates that a comparison is not performed. The value of the ETC bit is the same for cumu¬ 
lative and threshold parameters. 

TMC (Threshold Met Criteria) bit 

The threshold met criteria (TMC) field (see table 185) defines the basis for comparison of the cumulative and threshold val¬ 
ues. The TMC field is valid only if the ETC bit is set to one. The value of the TMC field is the same for cumulative and 
threshold parameters. 


Table 185 — Threshold met criteria 


Code 

Basis for comparison 

00b 

Every update of the cumulative value 

01b 

Cumulative value 

equal to 

threshold value 

10b 

Cumulative value 

not equal to 

threshold value 

11b 

Cumulative value 

greater than 

threshold value 


If the ETC bit is set to one and the result of the comparison is true, a unit attention condition shall be established for the ini¬ 
tiator port associated with every l_T nexus, with the additional sense code set to THRESHOLD CONDITION MET. 

LBIN (Last Binary) bit 

The list binary (LBIN) bit is only valid if the LP bit is set to one. If the LP bit is set to one and the LBIN bit is set to zero, then 
the list parameter is ASCII data. If the LP bit is set to one and the LBIN bit is set to one, then the list parameter is binary 
data. 

LP (List Parameter) bit 

The list parameter (LP) bit indicates the format of the log parameter. If an application client attempts to set the value of the 
LP bit to a value other than the one returned for the same parameter in the LOG SENSE command, the command shall be 
terminated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code 
set to INVALID FIELD IN PARAMETER LIST. 

0 An LP bit set to zero indicates that the parameter is a data counter. Data counters are associated with one or more 
events; the data counter is updated whenever one of these events occurs by incrementing the counter value. If each 
data counter has associated with it a vendor specific maximum value, then upon reaching this maximum value, the 
data counter shall not be incremented (i.e., it does not wrap). When a data counter reaches its maximum value, the 
device server shall set the associated DU bit to one. If the data counter is at or reaches its maximum value during 
the processing of a command, the device server shall complete the command. If the command completes correctly, 
except for the data counter being at its maximum value, and if the RLEC bit of the Control mode page is set to one, 
then the device server shall terminate the command with CHECK CONDITION status, with the sense key set to 
RECOVERED ERROR, and the additional sense code set to LOG COUNTER AT MAXIMUM. 
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1 An LP bit set to one indicates that the parameter is a list parameter. List parameters are not counters and thus the 
ETC and TMC fields shall be set to zero. 

If more than one list parameter is defined in a single log page, the following rules apply to assigning parameter 
codes: 

(a) The parameter updated last shall have a higher parameter code than the previous parameter, except 
as defined in rule b); and 

(b) When the maximum parameter code value supported by the logical unit is reached, the device server 
shall assign the lowest parameter code value to the next log parameter (i.e., wrap-around parameter 
codes). If the associated command completes correctly, except for the parameter code being at its 
maximum value, and if the RLEC bit of the Control mode page is set to one, then the command shall 
be terminated with CHECK CONDITION status, with the sense key set to RECOVERED ERROR, and 
the additional sense code set to LOG LIST CODES EXHAUSTED. 

Note. List parameters may be used to store the locations of defective blocks in the following manner. 
When a defective block is identified, a list parameter is updated to reflect the location and cause of 
the defect. When the next defect is encountered, the list parameter with the next higher parameter 
code is updated to record this defect. The size of the log page may be made vendor specific to 
accommodate memory limitations. It is recommended that one or more data counter parameters be 
defined for the log page to keep track of the number of valid list parameters and the parameter 
code of the parameter with the oldest recorded defect. This technique may be adapted to record 
other types of information. 

PARAMETER LENGTH field 

The PARAMETER LENGTH field specifies the length in bytes of the following parameter value. If the application client 
sends a parameter length value that results in the truncation of the parameter value, the command shall be terminated with 
CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID 
FIELD IN PARAMETER LIST. 

If the application client sends a log parameter value that is outside the range supported by the logical unit, and rounding is 
implemented for that parameter, the device server may either: 

(a) Round to an acceptable value and terminate the command as described in SPC - 3 clause 5.4; or 

(b) Terminate the command with CHECK CONDITION status, with the sense key set to ILLEGAL 
REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 

When any counter in a log page reaches its maximum value, incrementing of all counters in that log page shall cease until 
reinitialized by the application client via a LOG SELECT command. If the RLEC bit of the Control mode page is set to one, 
then the device server shall report the exception condition. 
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The page code assignments for the log pages are listed in table 186. 


Table 186 — Log page codes 


Page Code 

Log Page Name 

Reference 

OFh 

Application Client 

4.2.2 

01 h 

Buffer Over-Run/Under-Run 

4.2.5 

2Fh 

Informational Exceptions 

4.2.7 

OBh 

Last n Deferred Errors or Asynchronous Events 


07h 

Last n Error Events 


06h 

Non-Medium Error 

4.2.8 

18h 

Protocol Specific Port 

4.2.9 

03h 

Read Error Counter 

4.2.5 

04 h 

Read Reverse Error Counter 

4.2.5 

lOh 

Self-Test Results 

4.2.9 

OEh 

Start-Stop Cycle Counter 

4.2.10 

OOh 

Supported Log Pages 

4.2.11 

ODh 

Temperature 

4.2.12 

05h 

Verify Error Counter 

4.2.5 

02 h 

Write Error Counter 

4.2.5 

08h - OAh 

Reserved (may be used by specific device types) 


OCh 

Reserved (may be used by specific device types) 


11 h- 17h 

Reserved (may be used by specific device types) 


19h-2Eh 

Reserved (may be used by specific device types) 


3Fh 

Reserved 


30h - 3Eh 

Vendor specific 
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4.2.2 Application Client log page (OFh) 

The Application Client log page (see table 187) provides a place for application clients to store information. The 
page code for the application client page is OFh. 

Table 187 — Application client log page 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

PAGE CODE (OFh) 

1 

Reserved 

2 

(MSB) PAGE LENGTH (n-3) 

3 

(LSB) 


Application client log parameters 

4 

First application client log parameter 






Last application client log parameter 

n 



The PAGE CODE and PAGE LENGTH fields are described in 4.2.1. 

Parameter codes OOOOh through OFFFh are for general usage application client data. The intended use for this 
information is to aid in describing the system configuration and system problems, but the specific definition of 
the data is application client specific. The general usage application client data parameters all have the format 
shown in table 188. 


Table 188 — General usage application client parameter data 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

(MSB) PARAMETER CODE 

1 

(LSB) 

2 

DU DS TSD ETC TMC LBIN LP 

3 

PARAMETER LENGTH (FCh) 

4 

GENERAL USAGE PARAMETER BYTES 

255 



For general usage application client data, the value in the PARAMETER CODE field shall be between OOOOh 
and OFFFh. The first supported general usage application client parameter code shall be OOOOh and additional 
supported parameters shall be sequentially numbered. If any general usage parameter codes are imple¬ 
mented, the device shall support at least 64 general usage parameter descriptors and they shall be parameter 
codes OOOOh through 003Fh. 
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For the general usage application client parameter, the PARAMETER LENGTH value for each parameter shall 
be FCh. 

The state of the log parameter control bits for parameters OOOOh through OFFFh is specified in table 189. 

Table 189 — Parameter control bits for general usage parameters (OOOOh through OFFFh) 


Bit 

Value 

Description 

DU 

1 

Value provided by application client 

DS 

0 

Device server supports saving of parameter 

TSD 

0 

Device server manages saving of parameter 

ETC 

0 

No threshold comparison is made on this value 

TMC 

XX 

Ignored when the ETC bit is set to zero 

LBIN 

1 

The parameter is in binary format 

LP 

1 

The parameter is a list parameter 


The values stored in the GENERAL USAGE PARAMETER BYTES represent data sent to the device server in 
a previous LOG SELECT command. If a previous LOG SELECT command has not occurred, the data is ven¬ 
dor specific. 

In the application client log page, parameter codes lOOOh through FFFFh are reserved. 
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4.2.3 


Background Scan Results log page (15h) 


The Background Scan Results log page (see table 190) returns the background scanning status parameter 
and zero or more medium scan parameters when background scanning is supported. The background scan¬ 
ning status parameter provides information about background pre-scan and background medium scan opera¬ 
tions. 

Each medium error log entry corresponds to a logical block where an error was detected. If the medium scan 
log area is filled up, a new medium scan log entry overwrites the oldest entry. When a LOG SELECT command 
with PCR bit set to one is processed all medium scan parameters are deleted, however the values in the back¬ 
ground scanning status parameter shall not be affected. 


Table 190 — Background Scan Results log page 


Bit 

Byte 

7 

6 

5 4 3 2 1 

0 

0 

Reserved 

PAGE CODE (15h) 

1 

Reserved 

2 

(MSB) 

PAGE LENGTH (N-3) 


3 


(LSB) 


BACKGROUND SCAN RESULTS PARAMETERS 

4 


BACKGROUND SCANNING STATUS PARAMETERS 


19 



20 

(MSB) 

FIRST MEDIUM SCAN PARAMETER 


43 


(LSB) 


n-23 

(MSB) 



n 


(LSB) 


Table 191 defines the parameter codes for the Background Scan Results log page. 

Table 191. Background Scan Results Parameter codes 


Parameter code 

Description 

OOOOh 

Background scanning status 

0001h - 0800h 

Medium scan 

07FFhh - 7FFFh 

Reserved 
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The background scanning status parameter (see table 192) contains status information about the background 
pre-scan and background medium scan features. 

Table 192 — Background scanning status parameter format 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

(MSB) 

PARAMETER CODE (OOOOh) 


1 


(LSB) 

2 

DU DS TSD ETC TMC LBIN LP 

3 

PARAMETER LENGTH (OCh) 

4 

(MSB) 

POWER ON MINUTES 


7 


(LSB) 

8 

Reserved 

9 

BACKGROUND SCANNING STATUS 

10 


NUMBER OF SCANS PERFORMED 


11 



12 

(MSB) 

MEDIUM SCAN PROGRESS 


13 


(LSB) 

14 


Reserved 


15 




The contents of the DU, DS, TSD, ETC, LBIN, and LP bits and the TMC field are defined in SPC-4. 

PARAMETER LENGTH field 

The PARAMETER LENGTH field indicates the number of bytes remaining in the log parameter. 

POWER ON MINUTES field 

The POWER ON MINUTES field indicates the total power on minutes at the time the log page is requested. 
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BACKGROUND SCANNING STATUS field 

Table 193 specifies the meaning of the BACKGROUND SCANNING STATUS field. 

Table 193. Background Scanning Status codes 


Code 

Description 

OOh 

No scans active 

01 h 

Background medium scan is active 

02h 

Pre-scan is active 

03h 

Scan halted due to fatal error 

04h 

Scan halted due to a vendor specific pattern of errors 

05h 

Scan halted due to medium formatted without P-list 

06h 

Scan halted - vendor specific cause 

07h 

Scan halted due to temperature out of allowed range 

08h 

Scan suspended until BMS interval time (see Mode Parameters Background Control mode page) 
expires 

09h - FFh 

Reserved 


NUMBER OF SCANS PERFORMED field 

The NUMBER OF SCANS PERFORMED field indicates the number of background scans that have been per¬ 
formed since the SCSI target device was originally shipped by the manufacturer. 

MEDIUM SCAN PROGRESS field 

The MEDIUM SCAN PROGRESS field is a percent complete indication of the medium scan. The returned value is 
a numerator that has 65 536 (lOOOOh) as its denominator. 
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4.2.3.1 Medium Scan Parameter 

A medium scan parameter (see table 194) describes a defect location on the medium that was encountered by 
background scanning. 

Table 194 — Medium scan parameter format 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

(MSB) 

1 

PARAMETER CODE (0001 h - 0800h) 

(LSB) 

2 

DU DS TSD ETC TMC LBIN LP 

3 

(MSB) 

4 

POWER ON MINUTES 

(LSB) 

7 

BACKGROUND SCANNING STATUS 

8 

Reserved 

9 

BACKGROUND SCANNING STATUS 

10 


11 

NUMBER OF SCANS PERFORMED 

12 

(MSB) 

13 

MEDIUM SCAN PROGRESS 

(LSB) 

14 


15 

Reserved 


The contents of the DU, DS, TSD, ETC, LBIN, and LP bits and the TMC field are defined in SPC-4. 

PARAMETER LENGTH field 

The PARAMETER LENGTH field indicates the number of bytes remaining in the log parameter. 

POWER ON MINUTES field 

The POWER ON MINUTES field indicates the total power on minutes at the time the error was detected. 

REASSIGN STATUS field 

Table 195 specifies the REASSIGN STATUS field. 
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Table 195 — REASSIGN STATUS FIELD 


Code 

Description 

Oh 

No reassignment needed 

1h 

Reassignment pending receipt of a write command if automatic write reallocation is enabled or a 
REASSIGN BOLOCKS command. 

2h 

LBA successfully reassigned 

3h 

Reserved 

4h 

Reassign failed 

5h 

LBA recovered via re-write 

6h - Fh 

Reserved 


SENSE KEY, ADDITIONAL SENSE CODE, and the ADDITIONAL SENSE CODE QUALIFIER fields 

The SENSE KEY field, ADDITIONAL SENSE CODE field, and the ADDITIONAL SENSE CODE QUALIFIER 
field may contain a hierarchy of additional information relating to error conditions that occurred during back¬ 
ground scanning. They are represented in the same format used by the sense data (see SPC-4). 

LBA field 

The LBA field indicates the logical block address associated with the medium error. 
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4.2.4 


Cache Statistics page (37h) 


Log Page code 37h specifies Cache Statistics page. The page format is shown in Table 196. 

Table 196 — Cache Statistics page (37h) 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

OOh 

1 

PARAMETER CODE [1] 


[1] Parameter codes OOh through 04h are described following: 


OOh 

This parameter code represents the number of logical blocks that have been sent to a SCSI initiator port. 

01 h 

This parameter code represents the number of logical blocks that have been received from a SCSI initiator port. 

02h 

This parameter code represents the number of logical blocks read from the cache memory that have been sent to 
a SCSI initiator port. 

03h 

This parameter code represents the number of READ and WRITE commands that had data lengths equal or less 
than the current segment size. 

04h 

This parameter code represents the number of READ and WRITE commands that had data lengths greater that 
the current segment size. 


4.2.5 Error counter log pages (WRITE, READ, and VERIFY, 02h, 03h, and 05h) 

This subclause defines the error counter log pages (see table 197). 

Table 197 — Error counter log page codes 


Page Code 

Loge Page Name 

03h 

Read Error Counter 

05h 

Verify Error Counter 

02 h 

Write Error Counter 
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The log page format is defined in 4.2.1. A log page may return one or more log parameters that record events 
defined by the parameter codes. Table 198 defines the parameter codes for the error counter log pages. 


Table 198 — Parameter codes for error counter log pages 


Parameter code 

Description 

OOOOh 

Errors corrected without substantial delay. An error correction was applied to get perfect data 
(a.k.a., ECC on-the-fly). “Without Substantial Delay” means the correction did not postpone read¬ 
ing of later sectors (e.g., a revolution was not lost). The counter is incremented once for each log¬ 
ical block that requires correction. Two different blocks corrected during the same command are 
counted as two events. 

0001 h 

Errors corrected with possible delays. An error code or algorithm (e.g.,ECC, checksum) is 
applied in order to get perfect data with substantial delay. “With possible delay” means the correc¬ 
tion took longer than a sector time so that reading/writing of subsequent sectors was delayed 
(e.g, a lost revolution). The counter is incremented once for each logical block that requires cor¬ 
rection. A block with a double error that is correctable counts as one event and two different 
blocks corrected during the same command count as two events. 

0002h 

Total (e.g., rewrites or rereads). This parameter code specifies the counter counting the number 
of errors that are corrected by applying retries. This counts errors recovered, not the number of 
retries. If five retries were required to recover one block of data, the counter increments by one, 
not five. The counter is incremented once for each logical block that is recovered using retries. If 
an error is not recoverable while applying retries and is recovered by ECC, it isn’t counted by this 
counter; it will be counted by the counter specified by parameter code 01 h-Error Corrected With 
Possible Delay. 

0003h 

Total errors corrected. This counter counts the total of parameter code errors OOh, 01 h, and 02h. 
There is to be no “double counting” of data errors among these three counters. The sum of all 
correctable errors can be reached by adding parameter code 01 h and 02h errors, not by using 
this total. 

0004h 

Total times correction algorithm processed. This parameter code specifies the counter that counts 
the total number of retries, or “times the retry algorithm is invoked.” If after five attempts a counter 
02h type error is recovered, then five is added to this counter. If three retries are required to get a 
stable ECC syndrome before a counter 01 h type error is corrected, then those three retries are 
also counted here. The number of retries applied to unsuccessfully recover an error (counter 06h 
type error) are also counted by this counter. 

0005h 

Total bytes processed. This parameter code specifies the counter that counts the total number of 
bytes either successfully or unsuccessfully read, written, or verified (depending on the log page) 
from the drive. If a transfer terminates early because of an unrecoverable error, only the logical 
blocks up to and including the one with the unrecoverable error are counted. 

0006h 

Total uncorrected errors. This parameter code specifies the counter that contains the total num¬ 
ber of blocks for which an uncorrected data error has occurred. 

0007h - 7FFFh 

Reserved 

8000h - FFFFh 

Vendor specific 


Note. The exact definition of the error counters is not part of this standard. These counters should not be 
used to compare products because the products may define errors differently. 
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4.2.6 


Factory Log page (3Eh) 


Log page code 3Eh specifies factory status parameters (see Table 199). 

Table 199 — Factory Log page (3Eh) 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

OOh 

1 

PARAMETER CODE [1] [2] 


[1] PARAMETER CODE OOOOh-Power-on Time. This parameter code represents the number of drive power- 
on minutes. Currently the Power-on Time parameter (OOOOh) is the only parameter in this Log Page that is 
visible to OEM/customers. 

[2] PARAMETER CODE 08h. This parameter reports the time, in minutes, to the next scheduled interrupt for 
a S.M.A.R.T. measurement. 

4.2.7 Informational Exceptions log page (2Fh) 

The Informational Exceptions log page (see table 200) provides a place for reporting detail about informational 

exceptions. The page code for the Informational Exceptions log page is 2Fh. 

Table 200 — Informational Exceptions log page 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

PAGE CODE (2Fh) 

1 

Reserved 

2 

(MSB) PAGE LENGTH (n-3) 

3 

(LSB) 


INFORMATIONAL EXCEPTIONS LOG PARAMETERS 


FIRST INFORMATIONAL EXCEPTIONS LOG PARAMETER 



n 

LAST INFORMATIONAL EXCEPTIONS LOG PARAMETER 


The PAGE CODE and PAGE LENGTH fields are described in 4.2.1. 
Table 201 defines the parameter codes. 

Table 201 — Informational exceptions parameter codes 


Parameter code 

Description 

OOOOh 

Informational exceptions general parameter data 

0001 h - FFFFh 

Vendor specific 
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The informational exceptions general parameter data page has the format shown in table 202. 


Table 202 — Informational exceptions general parameter data 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

(MSB) PARAMETER CODE (OOOOh) 

1 

(LSB) 

2 

DU DS TSD ETC TMC LBIN LP 

3 

PARAMETER LENGTH (N-3) 

4 

INFORMATIONAL EXCEPTION ADDITIONAL SENSE CODE 

5 

INFORMATIONAL EXCEPTION ADDITIONAL SENSE CODE QUALIFIER 

6 

MOST RECENT TEMPERATURE READING 

7 

Vendor specific 

n 



The values of the log parameter control bits for self test results log parameters are specified in table 203. 

Table 203 — Parameter control bits for Informational exceptions log parameter (OOOOh) 


Bit 

Value 

Description 

DU 

0 

Value provided by device server 

DS 

0 

Device server supports saving of parameter 

TSD 

0 

Device server manages saving of parameter 

ETC 

0 

No threshold comparison is made on this value 

TMC 

XX 

Ignored when the ETC bit is set to zero 

LBIN 

1 

The parameter is in binary format 

LP 

1 

The parameter is a list parameter 


PARAMETER LENGTH field 

The PARAMETER LENGTH field is described in 4.2.1. The parameter length shall be at least 04h. 

INFORMATIONAL EXCEPTION ADDITIONAL SENSE CODE field 

If the INFORMATIONAL EXCEPTION ADDITIONAL SENSE CODE field contains zero, no informational exception condi¬ 
tion is pending and contents of the INFORMATIONAL EXCEPTION ADDITIONAL SENSE CODE QUALIFIER field are 
unspecified. If the INFORMATIONAL EXCEPTION ADDITIONAL SENSE CODE field contains any value other than zero, 
an informational exception condition exists that has an additional sense code indicated by INFORMATIONAL EXCEPTION 
ADDITIONAL SENSE CODE field and an ADDITIONAL SENSE CODE QUALIFIER indicated by the INFORMATIONAL 
EXCEPTION ADDITIONAL SENSE CODE QUALIFIER field. 

MOST RECENT TEMPERATURE READING field 

The MOST RECENT TEMPERATURE READING field indicates the temperature in degrees Celsius of the SCSI target 
device at the time the LOG SENSE command is performed. Temperatures equal to or less than zero degrees Celsius shall 
be indicated by a value of zero. If the device server is unable to detect a valid temperature because of a sensor failure or 
other condition, the value returned shall be FFh. The temperature should be reported with an accuracy of plus or minus 
three Celsius degrees while the device is operating at a steady state within the environmental limits specified for the device. 
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4.2.8 Non-Medium Error log page (06h) 

The Non-Medium Error log page (page code 06h) provides for summing the occurrences of recoverable error 
events other than write, read, or verify failures. No discrimination among the various types of events is pro¬ 
vided by parameter code (see table 204). Vendor specific discrimination may be provided through Seagate 
specific parameter codes. 


Table 204 — Non-medium error event parameter codes 


Parameter code 

Description 

OOOOh 

Non-medium error count 

0001 h - 7FFFh 

Reserved 

8000h - FFFFh 

Vendor specific error counts 


Log page code 06h specifies non-medium errors. The page format is shown in Table 205. 

Table 205 — Non-Medium Error page (06h) 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

OOh 

1 

PARAMETER CODE [] 


PARAMETER CODE OOh is the only code supported for this page and it represents the number of recoverable 
error events other than WRITE, READ, or VERIFY errors. 
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4.2.9 


Self-Test Results log page (1 Oh) 


The Self-Test Results log page (see table 206) provides the results from the 20 most recent self-tests (see 
SPC-4 clause 5.5). Results from the most recent self-test or the self-test currently in progress shall be reported 
in the first self-test log parameter; results from the second most recent self-test shall be reported in the second 
self-test log parameter; etc. If fewer than 20 self-tests have occurred, the unused self-test log parameter 
entries shall be zero filled. 


Table 206 — Self-Test Results log page 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

PAGE CODE (lOh) 

1 

Reserved 

2 

(MSB) PAGE LENGTH (190h) 

4 

(LSB) 


SELF-TEST RESULTS LOG PARAMETERS 


FIRST SELF-TEST RESULTS LOG PARAMETER 

23 

(most recent) 



384 

TWENTIETH SELF-TEST RESULTS LOG PARAMETER 

403 

(least recent) 


The PAGE CODE and PAGE LENGTH fields are described in 4.2.1. 
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Table 207 shows the format of one self-test log parameter. 

Table 207 — Self-test results log parameter format 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

(MSB) PARAMETER CODE (0001 h TO 0014h) 

1 

(LSB) 

2 

DU DS TSD ETC TMC LBIN LP 

3 

PARAMETER LENGTH (lOh) 

4 

SELF-TEST CODE Reserved SELF-TEST RESULTS 

5 

SELF-TEST NUMBER 

6 

(MSB) TIMESTAMP 

7 

(LSB) 

8 

(MSB) ADDRESS OF FIRST FAILURE 

15 

(LSB) 

16 

Reserved SENSE KEY 

17 

ADDITIONAL SENSE CODE 

18 

ADDITIONAL SENSE CODE QUALIFIER 

19 

Vendor specific 


PARAMETER CODE field 

The PARAMETER CODE field identifies the log parameter being transferred. The PARAMETER CODE field 
for the results of the most recent self-test shall contain 0001 h; the PARAMETER CODE field for the results of 
the second most recent test shall contain 0002h; etc. 

The values of the log parameter control bits for self test results log parameters is specified in table 208. 

Table 208 — Parameter control bits for self-test results log parameters 


Bit 

Value 

Description 

DU 

0 

Value provided by device server 

DS 

0 

Device server supports saving of parameter 

TSD 

0 

Device server manages saving of parameter 

ETC 

0 

No threshold comparison is made on this value 

TMC 

XX 

Ignored when the ETC bit is set to zero 

LBIN 

1 

The parameter is in binary format 

LP 

1 

The parameter is a list parameter 


PARAMETER LENGTH field 

The PARAMETER LENGTH field shall contain lOh. 
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SELF-TEST CODE field 


The SELF-TEST CODE field contains the value in the SELF-TEST CODE field of the SEND DIAGNOSTIC 
command that initiated this self-test. 

Table 209 defines the content of the SELF-TEST RESULTS field. 

Table 209 — SELF-TEST RESULTS field 


Code 

Description 

Oh 

The self-test completed without error. 

1h 

The background self-test was aborted by the application client using a SEND DIAGNOSTIC command (see 
3.43) with the SELF-TEST CODE field set to 100b (i.e., abort background self-test). 

2h 

The self-test routine was aborted by an application client using a method other than a SEND DIAGNOSTIC 
command with the SELF-TEST CODE field set to 100b (e.g., by a task management function, or by issuing an 
exception command as defined in SPC-4 clause 5.5). 

3h 

An unknown error occurred while the device server was processing the self-test and the device server was 
unable to complete the self-test. 

4h 

The self-test completed with a failure in a test segment, and the test segment that failed is not known. 

5h 

The first segment of the self-test failed. 

6h 

The second segment of the self-test failed. 

7h 

Another segment of the self-test failed and which test is indicated by the contents of the SELF-TEST NUMBER 
field. 

8h-Eh 

Reserved 

Fh 

The self-test is in progress. 


SELF-TEST NUMBER field 

The SELF-TEST NUMBER field identifies the self-test that failed and consists of either: 

a) The number of the segment that failed during the self-test; or 

b) The number of the test that failed and the number of the segment in which the test was run, using a vendor 
specific method for placing the two values in the one field. 

When the segment in which the failure occurred is not able to be identified or need not be identified, the SELF-TEST NUM¬ 
BER field shall contain OOh. 

TIMESTAMP field 

The TIMESTAMP field contains the total accumulated power-on hours for the device server at the time the self-test was 
completed. If the test is still in progress, the content of the TIMESTAMP field shall be zero. If the power-on hours for the 
device server at the time the self-test was completed is greater than FFFFh then the content of the TIMESTAMP field shall 
be FFFFh. 

ADDRESS OF FIRST FAILURE field 

The ADDRESS OF FIRST FAILURE field contains information that locates the failure on the media. If the logical unit imple¬ 
ments logical blocks, the content of the ADDRESS OF FIRST FAILURE field is the first logical block address where a self¬ 
test error occurred. This implies nothing about the quality of any other logical block on the logical unit, since the testing dur¬ 
ing which the error occurred may not have been performed in a sequential manner. This value shall not change (e.g., as the 
result of block reassignment). The content of the ADDRESS OF FIRST FAILURE field shall be FFFF FFFF FFFF FFFFh if 
no errors occurred during the self-test or if the error that occurred is not related to an identifiable media address. 
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SENSE KEY, ADDITIONAL SENSE CODE, and ADDITIONAL SENSE CODE QUALIFIER fields 

The SENSE KEY field, ADDITIONAL SENSE CODE field, and ADDITIONAL SENSE CODE QUALIFIER field may contain 
a hierarchy of additional information relating to error or exception conditions that occurred during the self-test represented 
in the same format used by the sense data (see REQUEST SENSE command). 

4.2.10 Start-Stop Cycle Counter log page (OEh) 

This subclause defines the Start-Stop Cycle Counter log page (page code OEh). A device server that imple¬ 
ments the Start-Stop Cycle Counter log page shall implement one or more of the defined parameters. Table 
210 shows the Start-Stop Cycle Counter log page with all parameters present. 

Table 210 — Start-Stop Cycle Counter log page (Sheet 1 of 2) 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

PAGE CODE (OEh) 

1 

Reserved 

2 

(MSB) PAGE LENGTH (24h) 

3 

(LSB) 

4 

(MSB) PARAMETER CODE 0001H 

5 

DATE OF MANUFACTURE 

(LSB) 

6 

DU DS TSD ETC TMC LBIN LP 

7 

PARAMETER LENGTH (06h) 

8 

(MSB) YEAR OF MANUFACTURE (4 ASCII CHARACTERS) 

11 

(LSB) 

12 

(MSB) WEEK OF MANUFACTURE (2 ASCII CHARACTERS) 

13 

(LSB) 

14 

(MSB) PARAMETER CODE 0002H 

15 

h ACCOUNTING DATE 

(LSB) 

16 

DU DS TSD ETC TMC LBIN LP 

17 

PARAMETER LENGTH (06h) 

18 

(MSB) ACCOUNTING DATE YEAR (4 ASCII CHARACTERS) 

21 

(LSB) 

22 

(MSB) ACCOUNTING DATE WEEK (2 ASCII CHARACTERS) 

23 

(LSB) 

24 

(MSB) PARAMETER CODE 0003H 

25 

SPECIFIED CYCLE COUNT OVER DEVICE LIFETIME 

(LSB) 

26 

DU DS TSD ETC TMC LBIN LP 

27 

PARAMETER LENGTH (04h) 
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Table 210 — Start-Stop Cycle Counter log page (Sheet 2 of 2) 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

28 

(MSB) 


SPECIFIED CYCLE COUNT OVER DEVICE LIFETIME 
(4-BYTE BINARY NUMBER) 



31 




(LSB) 

32 

(MSB) 



PARAMETER CODE 0004H 




33 



AOOUMULAItU b lAri l-b 1 Ur OYOLtb 


(LSB) 

34 

DU 

DS 

TSD 

ETC 

TMC 

LBIN 

LP 

35 

PARAMETER LENGTH (04h) 

36 

(MSB) 


ACCUMULATED START-STOP CYCLES 
(4-BYTE BINARY NUMBER) 



39 




(LSB) 


The year and week in the year that the SCSI target device was manufactured shall be contained in the param¬ 
eter value of the log parameter in which the parameter code is 0001 h. The date of manufacture shall not be 
saveable by the application client using the LOG SELECT command (i.e., the log parameter DS bit shall be set 
to one). The date is expressed in numeric ASCII characters (30h - 39h) in the form YYYYWW, as shown in 
table 210. For the log parameter in which the parameter code value is 0001 h, the values of the parameter con¬ 
trol bits are defined in table 211. 


Table 211 — Parameter control bits for date of manufacture parameter (0001 h) 


Bit 

Value 

Description 

DU 

0 

Value provided by device server 

DS 

1 

Device server does not support saving of parameter 

TSD 

0 

Device server manages saving of parameter 

ETC 

0 

No threshold comparison is made on this value 

TMC 

XX 

Ignored when the ETC bit is set to zero 

LBIN 

0 

The parameter is in ASCII format 

LP 

1 

The parameter is a list parameter 


The accounting date specified by parameter code 0002h may be saved using a LOG SELECT command to 
indicate when the device was placed in service. If the parameter is not yet set or is not settable, the default 
value placed in the parameter field shall be 6 ASCII space characters (20h). The field shall not be checked for 
validity by the device server. 
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For the log parameter in which the parameter code value is 0002h, the values of the parameter control bits are 
defined in table 212. 

Table 212 — Parameter control bits for accounting date parameter (0002h) 


Bit 

Value 

Description 

DU 

0 

Value provided by device server 

DS 

0 or 1 

Device server optionally supports saving of parameter 

TSD 

0 

Device server manages saving of parameter 

ETC 

0 

No threshold comparison is made on this value 

TMC 

XX 

Ignored when the ETC bit is set to zero 

LBIN 

0 

The parameter is in ASCII format 

LP 

i 

The parameter is a list parameter 


The parameter value in the specified cycle count over device lifetime log parameter (parameter code 0003h) 
shall contain a four-byte binary value that indicates how many stop-start cycles may typically be performed 
over the lifetime of the SCSI target device without degrading the SCSI target device’s operation or reliability 
outside the limits specified by the manufacturer of the SCSI target device. The specified cycle count over 
device lifetime parameter shall not be saveable by the application client using the LOG SELECT command 
(i.e., the log parameter DS bit shall be set to one). For the log parameter in which the parameter code value is 
0003h, the values of the parameter control bits are defined in table 213. 


Table 213 — Parameter control bits for start-stop cycle counter parameters (0003h and 0004h) 


Bit 

Value 

Description 

DU 

0 

Value provided by device server 

DS 

1 

Device server does not support saving of parameter 

TSD 

0 

Device server manages saving of parameter 

ETC 

0 

No threshold comparison is made on this value 

TMC 

XX 

Ignored when the ETC bit is set to zero 

LBIN 

1 

The parameter is in binary format 

LP 

1 

The parameter is a list parameter 


The parameter value in the accumulated start-stop cycles log parameter (parameter code 0004h) shall contain 
a four-byte binary value that indicates how many stop-start cycles the SCSI target device has detected since its 
date of manufacture. The accumulated start-stop cycles parameter shall not be saveable by the application cli¬ 
ent using the LOG SELECT command (i.e., the log parameter DS bit shall be set to one). The time at which the 
count is incremented during a start-stop cycle is vendor specific. For rotating magnetic storage devices, a sin¬ 
gle start-stop cycle is defined as an operational cycle that begins with the disk spindle at rest, continues while 
the disk accelerates to its normal operational rotational rate, continues during the entire period the disk is rotat¬ 
ing, continues as the disk decelerates toward a resting state, and ends when the disk is no longer rotating. For 
devices without a spindle or with multiple spindles, the definition of a single start-stop cycle is vendor specific. 
The count is incremented by one for each complete start-stop cycle. No comparison with the value of parame¬ 
ter 0003h shall be performed by the device server. For the log parameter in which the parameter code value is 
0004h, the values of the parameter control bits are defined in table 213. 
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4.2.11 Supported Log Pages log page (OOh) 

The Supported Log Pages log page (see table 214) returns the list of log pages implemented by the logical 
unit. Logical units that implement the LOG SENSE command shall implement this log page. 

Table 214 — Supported log pages 


Bit 

Byte 

7 

6 5 4 3 2 1 0 

0 

PAGE CODE (OOh) 

1 

Reserved 

2 

(MSB) 

PAGE LENGTH (N-3) 

3 


(LSB) 

4 

SUPPORTED PAGE LIST 

n 



This log page is not defined for the LOG SELECT command. This log page returns the list of supported log 
pages for the specified logical unit. 

The PAGE LENGTH field indicates the length in bytes of the following supported log page list. 

The SUPPORTED PAGE LIST field shall contain a list of all log page codes implemented by the logical unit in 
ascending order beginning with page code OOh. 
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4.2.12 Temperature log page (ODh) 


This subclause defines the Temperature log page (page code ODh). A device server that implements the Tem¬ 
perature log page shall implement parameter OOOOh and may implement parameter 0001 h. Table 215 shows 
the Temperature log page with all parameters present. 

Table 215 — Temperature log page 


Bit 

Byte 

7 

6 5 4 3 2 1 

0 

0 

PAGE CODE (ODh) 

1 

Reserved 

2 

(MSB) 

PAGE LENGTH (OCh) 


3 


(LSB) 

4 

(MSB) 

PARAMETER CODE OOOOH 

TEMPERATURE 


5 


(LSB) 

6 

DU 

DS TSD ETC TMC LBIN 

LP 

7 

PARAMETER LENGTH (02h) 

8 

Reserved 

9 

TEMPERATURE (DEGREES CELSIUS) 

10 

(MSB) 

PARAMETER CODE 0001H 

REFERENCE TEMPERATURE 


11 


(LSB) 

12 

DU 

DS TSD ETC TMC LBIN 

LP 

13 

PARAMETER LENGTH (02h) 

14 

Reserved 

15 

REFERENCE TEMPERATURE (DEGREES CELSIUS) 


The parameter value in the temperature log parameter (parameter code OOOOh) shall contain a one-byte binary 
value that indicates the temperature of the SCSI target device in degrees Celsius at the time the LOG SENSE 
command is performed. Temperatures equal to or less than zero degrees Celsius shall be indicated by a value 
of zero. If the device server is unable to detect a valid temperature because of a sensor failure or other condi¬ 
tion, then the value returned shall be FFh. The temperature should be reported with an accuracy of plus or 
minus three Celsius degrees while the SCSI target device is operating at a steady state within its environmen- 
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tal limits. No comparison is performed between the temperature value specified in parameter OOOOh and the 
reference temperature specified in parameter 0001 h. The state of the parameter control bits for parameter 
OOOOh is specified in table 216. 

Table 216 — Parameter control bits for temperature parameters (OOOOh and 0001 h) 


Bit 

Value 

Description 

DU 

0 

Value provided by device server 

DS 

1 

Device server does not support saving of parameter 

TSD 

0 

Device server manages saving of parameter 

ETC 

0 

No threshold comparison is made on this value 

TMC 

XX 

Ignored when the ETC bit is set to zero 

LBIN 

i 

The parameter is in binary format 

LP 

i 

The parameter is a list parameter 


A reference temperature for the device may be returned by the device server as follows: 

(a) If a reference temperature is returned, the parameter value in the reference temperature log parameter 
(parameter code 0001 h) shall contain a one-byte binary value that indicates the maximum reported 
sensor temperature in degrees Celsius at which the SCSI target device is capable of operating contin¬ 
uously without degrading the SCSI target device's operation or reliability beyond manufacturer 
accepted limits; or 

(b) If no reference temperature is returned, then: 

a) The log parameter with parameter code 0001 h may not be included in the log page; or 

b) The parameter value in the reference temperature log parameter (parameter code 0001 h) may be set to FFh. 

The reference temperature may change for vendor specific reasons. The state of the parameter control bits for 
parameter 0001 h is specified in table 216. 
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4.3 


Mode parameters 


4.3.1 Mode parameters overview 

This subclause describes the mode parameter headers, block descriptors, and mode pages used with MODE 
SELECT command (see 3.12 and 3.13) and MODE SENSE command (see 3.14 and 3.15) that are applicable 
to all SCSI devices. Subpages are identical to mode pages except that they include a SUBPAGE CODE field 
that further differentiates the mode page contents. Mode pages specific to each device type are described in 
the command standard that applies to that device type. 

Note. Many of the mode parameters in the following pages are changeable. A MODE SENSE com¬ 
mand with the PC bit set to one will return a mask indicating the mode parameters that may 
be changed by a SCSI initiator port. Seagate disc drive product manuals indicate which 
pages a drive supports, what the default mode values are, and what mode parameters may 
be changed. 

4.3.2 Mode parameter list format 

The mode parameter list shown in table 217 contains a header, followed by zero or more block descriptors, fol¬ 
lowed by zero or more variable-length mode pages. Parameter lists are defined for each device type. 


Table 217 — Mode parameter list 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 


MODE PARAMETER HEADER 


BLOCK DESCRIPTOR(S) 


MODE PAGE(S) OR VENDOR SPECIFIC (E.G., PAGE CODE SET TO ZERO) 


4.3.3 Mode parameter header formats 

The mode parameter header that is used by the MODE SELECT(6) command (see 3.12) and the MODE 
SENSE(6) command (see 3.14) is defined in table 218. 

Table 218 — Mode parameter header(6) 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

MODE DATA LENGTH 

1 

MEDIUM TYPE 

2 

DEVICE-SPECIFIC PARAMETER 

3 

BLOCK DESCRIPTOR LENGTH 
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The mode parameter header that is used by the MODE SELECT(IO) command (see 3.13) and the MODE 
SENSE(IO) command (see 3.15) is defined in table 219. 

Table 219 — Mode parameter header(IO) 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

(MSB) MODE DATA LENGTH 

1 

(LSB) 

2 

MEDIUM TYPE 

3 

DEVICE-SPECIFIC PARAMETER 

4 

Reserved LONGLBA 

5 

Reserved 

6 

(MSB) BLOCK DESCRIPTOR LENGTH 

7 

(LSB) 


MODE DATA LENGTH field 

When using the MODE SENSE command, the MODE DATA LENGTH field indicates the length in bytes of the following 
data that is available to be transferred. The mode data length does not include the number of bytes in the MODE DATA 
LENGTH field. When using the MODE SELECT command, this field is reserved. 

Note. Logical units that support more than 256 bytes of block descriptors and mode pages may need to 
implement ten-byte mode commands. The mode data length field in the six-byte CDB header limits 
the returned data to 256 bytes. 

MEDIUM TYPE field 

The contents of the MEDIUM TYPE field are unique for each device type. Refer to the mode parameters subclause of the 
specific device type command standard for definition of these values. Some device types reserve this field. 

DEVICE-SPECIFIC PARAMETER field 

The DEVICE-SPECIFIC PARAMETER field is unique for each device type. Refer to the mode parameters subclause of the 
specific device type command standard for definition of this field. Some device types reserve all or part of this field. 

LONGLBA (Long LBA) bit 

0 If the Long LBA (LONGLBA) bit is set to zero, the mode parameter block descriptor(s), if any, are each eight bytes 
long and have the format described in 4.3.4.1. 

1 If the LONGLBA bit is set to one, the mode parameter block descriptor(s), if any, are each sixteen bytes long and 
have a format described in a command standard. 

BLOCK DESCRIPTOR LENGTH field 

The BLOCK DESCRIPTOR LENGTH field contains the length in bytes of all the block descriptors. It is equal to the number 
of block descriptors times eight if the LONGLBA bit is set to zero or times sixteen if the LONGLBA bit is set to one, and 
does not include mode pages or vendor specific parameters (e.g., page code set to zero), if any, that may follow the last 
block descriptor. A block descriptor length of zero indicates that no block descriptors are included in the mode parameter 
list. This condition shall not be considered an error. 
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4.3.4 


Mode parameter block descriptor formats 


4.3.4.1 General block descriptor format 

When the LONGLBA bit is set to zero (see 4.3.3), the mode parameter block descriptor format for all device 
types except direct access block devices (see SBC-2) is shown in table 220. 

Table 220 — General mode parameter block descriptor 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

DENSITY CODE 

1 

(MSB) NUMBER OF BLOCKS 

2 


3 

(LSB) 

4 

Reserved 

5 

(MSB) BLOCK LENGTH 

6 


7 

(LSB) 


Block descriptors specify some of the medium characteristics for all or part of a logical unit. Support for block 
descriptors is optional. Each block descriptor contains a DENSITY CODE field, a NUMBER OF BLOCKS field, 
and a BLOCK LENGTH field. Block descriptor values are always current (i.e., saving is not supported). A unit 
attention condition (see 3.11 and SAM-3) shall be established when any block descriptor values are changed. 
Command standards may place additional requirements on the general mode parameter block descriptor. 
Requirements in the command standards that conflict with requirements defined in this subclause shall take 
precedence over the requirements defined in this subclause. 

DENSITY CODE field 

The DENSITY CODE field is unique for each device type. Refer to the mode parameters subclause of the specific device 
type command standard for definition of this field. Some device types reserve all or part of this field. 

NUMBER OF BLOCKS field 

The NUMBER OF BLOCKS field specifies the number of logical blocks on the medium to which the DENSITY CODE field 
and BLOCK LENGTH field apply. A value of zero indicates that all of the remaining logical blocks of the logical unit shall 
have the medium characteristics specified. 

If the number of logical blocks on the medium exceeds the maximum value that may be specified in the NUM¬ 
BER OF BLOCKS field, a value of FFFFFFh indicates that all of the remaining logical blocks of the logical unit 
shall have the medium characteristics specified. 

NOTES 

1. There may be implicit association between parameters defined in the mode pages and block descrip¬ 
tors. In this case, the device server may change parameters not explicitly sent with the MODE 
SELECT command. A subsequent MODE SENSE command may be used to detect these changes. 

2. The number of remaining logical blocks may be unknown for some device types. 

BLOCK LENGTH field 

The BLOCK LENGTH field specifies the length in bytes of each logical block described by the block descriptor. For sequen¬ 
tial-access devices, a block length of zero indicates that the logical block size written to the medium is specified by the 
TRANSFER LENGTH field in the CDB (see SSC-2). 
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4.3.5 


Mode page and subpage formats and page codes 


The page_0 mode page format is defined in table 221. 

Table 221 — Page_0 mode page format 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

PS 

SPF (OB) 

PAGE CODE 

1 

PAGE LENGTH (N-1) 

2 




MODE PARAMETERS 




n 










The SUBPAGE mode page format is defined in table 222. 

Table 222 — SUB_PAGE mode page format 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

PS 

SPF (1b) 

PAGE CODE 

1 

SUBPAGE CODE 

2 

(MSB) 



PAGE LENGTH (N-3) 




3 








(LSB) 

4 




MODE PARAMETERS 




n 










Each mode page contains a PS bit, an SPF bit, a PAGE CODE field, a PAGE LENGTH field, and a set of mode 
parameters. The page codes are defined in this subclause and in the mode parameter subclauses in the com¬ 
mand standard for the specific device type. Each mode page with a SPF bit set to one contains a SUBPAGE 
CODE field. 

SPF (SubPage Format) bit 

0 A SubPage Format (SPF) bit set to zero indicates that the page_0 mode page format is being used. 

1 A SPF bit set to one indicates that the SUB_PAGE mode page format is being used. 

PS (parameters saveable) bit 

1 When using the MODE SENSE command, a parameters saveable (PS) bit set to one indicates that the mode page 
may be saved by the logical unit in a nonvolatile, vendor specific location. 

0 A PS bit set to zero indicates that the device server is not able to save the supported parameters. When using the 
MODE SELECT command, the PS bit is reserved. 

PAGE CODE and SUBPAGE CODE fields 

The PAGE CODE and SUBPAGE CODE fields identify the format and parameters defined for that mode page. Some page 
codes are defined as applying to all device types and other page codes are defined for the specific device type. The page 
codes that apply to a specific device type are defined in the command standard for that device type. The applicability of 
each subpage code matches that of the page code with which it is associated. 


254 


SCSI Commands Reference Manual, Rev. A 





When using the MODE SENSE command, if page code OOh (vendor specific mode page) is implemented, the 
device server shall return that mode page last in response to a request to return all mode pages (page code 
3Fh). When using the MODE SELECT command, this mode page should be sent last. 

PAGE LENGTH field 

The PAGE LENGTH field specifies the length in bytes of the mode parameters that follow. If the application client does not 
set this value to the value that is returned for the mode page by the MODE SENSE command, the command shall be termi¬ 
nated with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to 
INVALID FIELD IN PARAMETER LIST. The logical unit may implement a mode page that is less than the full mode page 
length defined, provided no field is truncated and the PAGE LENGTH field correctly specifies the actual length imple¬ 
mented. 

The mode parameters for each mode page are defined in the following subclauses, or in the mode parameters 
subclause in the command standard for the specific device type. Mode parameters not implemented by the 
logical unit shall be set to zero. 
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Table 223 defines the mode pages that are applicable to all device types that implement the MODE SELECT 
and MODE SENSE commands. 

Table 223 — Mode page codes and subpage codes 


Page code 

Subpage code 

Mode Page Name 

Reference 

OAh 

OOh 

Control 

4.3.9 

OAh 

01 h 

Control Extension 

4.3.10 

02 h 

OOh 

Disconnect-Reconnect 

4.3.11 

15h 

OOh 

Extended 


16h 

OOh 

Extended Device-Type Specific 


ICh 

OOh 

Informational Exceptions Control 

4.3.13 

09h 

OOh 

Obsolete 


1 Ah 

OOh 

Power Condition 

4.3.15 

18h 

OOh 

Protocol Specific LUN 

4.3.17 

18h 

Olh-FEh 

(See specific SCSI transport protocol) 


19h 

OOh 

Protocol Specific Port 

4.3.18 

19h 

01 h - FEh 

(See specific SCSI transport protocol) 


01 h 

OOh - FEh 

(See specific device type) 


03h 

OOh 

Format Device mode page (Obsolete) 


04h - 08h 

OOh - FEh 

(See specific device type) 


OBh-14h 

OOh - FEh 

(See specific device type) 


1 Bh 

OOh - FEh 

(See specific device type) 


IDh-IFh 

OOh - FEh 

(See specific device type) 


20h - 3Eh 

OOh - FEh 

(See specific device type) 


OOh 

not applicable 

Vendor specific (does not require page format) 


3Fh 

OOh 

Return all pages a 


3Fh 

FFh 

Return all pages and subpages a 


OOh - 3Eh 

FFh 

Return all subpages a 


All page code and subpage code combinations not shown in this table are reserved. 

a Valid only for the MODE SENSE command 


4.3.6 Mode parameter block descriptors 

4.3.6.1 Mode parameter block descriptors overview 

If the device server returns a mode parameter block descriptor, it shall return a short LBA mode parameter 
block descriptor (see 6.3.2.2) in the mode parameter data in response to: 

a) a MODE SENSE (6) command; or 

b) a MODE SENSE (10) command with the LLBAA bit set to zero. 
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If the device server returns a mode parameter block descriptor and the number of blocks is greater than 
FFFFFFFFh, it may return a long LBA mode parameter block descriptor (see 6.3.2.3) in the mode parameter 
data in response to a MODE SENSE (10) command with the LLBAA bit set to one. 

If the application client sends a mode parameter block descriptor in the mode parameter list, it shall send a 
short LBA mode parameter block descriptor (see 6.3.2.2) for a MODE SELECT (6) command. 

If the application client sends a mode parameter block descriptor in the mode parameter list, it may send a long 
LBA mode parameter block descriptor (see 6.3.2.3) for a MODE SELECT (10) command. 

Support for the mode parameter block descriptors is optional. The device server shall establish a unit attention 
condition with the additional sense code of MODE PARAMETERS CHANGED (see SPC-4 and SAM-4) when 
the block descriptor values are changed. 

4.3.6.2 Short LBA mode parameter block descriptor 

Table 105 defines the block descriptor for direct-access block devices used: 

a) with the MODE SELECT (6) and MODE SENSE (6) commands; and 

b) with the MODE SELECT (10) and MODE SENSE (10) commands when the LONGLBA bit is set to zero in the 
mode parameter header (see SPC-4). 


Table 224 — Short LBA mode parameter block descriptor 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

(MSB) NUMBER OF BLOCKS 

3 

(LSB) 

4 

Reserved 

5 

(MSB) BLOCK LENGTH 

7 

(LSB) 


A device server shall respond to a MODE SENSE command (see SPC-4) by reporting the number of blocks 
specified in the NUMBER OF BLOCKS field sent in the last MODE SELECT command that contained a mode 
parameter block descriptor. If no MODE SELECT command with a mode parameter block descriptor has been 
received then the current number of blocks shall be returned. To determine the number of blocks at which the 
logical unit is currently formatted, the application client shall use the READ CAPACITY command (see 5.11) 
rather than the MODE SELECT command. 

On a MODE SENSE command, the device server may return a value of zero indicating that it does not report 
the number of blocks in the short LBA mode parameter block descriptor. 

On a MODE SENSE command, if the number of logical blocks on the medium exceeds the maximum value 
that is able to be specified in the NUMBER OF BLOCKS field, the device server shall return a value of 
FFFFFFFFh. 

If the logical unit does not support changing its capacity by changing the NUMBER OF BLOCKS field using the 
MODE SELECT command (see SPC-4), the value in the NUMBER OF BLOCKS field is ignored. If the device 
supports changing its capacity by changing the NUMBER OF BLOCKS field, then the NUMBER OF BLOCKS 
field is interpreted as follows: 

a) If the NUMBER OF BLOCKS field is set to zero, the logical unit shall retain its current capacity if the block 
length has not changed. If the NUMBER OF BLOCKS field is set to zero and the content of the BLOCK LENGTFI 
field (i.e., new block length) is different than the current block length, the logical unit shall be set to its maximum 
capacity when the new block length takes effect (i.e., after a successful FORMAT UNIT command); 

b) If the NUMBER OF BLOCKS field is greater than zero and less than or equal to its maximum capacity, the log- 
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ical unit shall be set to that number of blocks. If the content of the BLOCK LENGTH field is the same as the current 
block length, the logical unit shall not become format corrupt. This capacity setting shall be retained through power 
cycles, hard resets, logical unit resets, and l_T nexus losses. If the content of the BLOCK LENGTH field is the 
same as the current block length this capacity setting shall take effect on successful completion of the MODE 
SELECT command. If the content of the BLOCK LENGTH field (i.e., new block length) is different than the current 
block length this capacity setting shall take effect when the new block length takes effect (i.e., after a successful 
FORMAT UNIT command); 

c) If the NUMBER OF BLOCKS field is set to a value greater than the maximum capacity of the device and less 
than FFFFFFFFh, then the MODE SELECT command shall be terminated with CHECK CONDITION status with 
the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER 
LIST. The logical unit shall retain its previous block descriptor settings; or 

d) If the NUMBER OF BLOCKS field is set to FFFFFFFFh, the logical unit shall be set to its maximum capacity. If 
the content of the NUMBER OF BLOCKS field is the same as the current block length, the logical unit shall not 
become format corrupt. This capacity setting shall be retained through power cycles, hard resets, logical unit 
resets, and l_T nexus losses. If the content of the BLOCK LENGTH field is the same as the current block length 
this capacity setting shall take effect on successful completion of the MODE SELECT command. If the content of 
the BLOCK LENGTH field (i.e., new block length) is different than the current block length this capacity setting 
shall take effect when the new block length takes effect (i.e., after a successful FORMAT UNIT command). 

The BLOCK LENGTH field specifies the length in bytes of each logical block. No change shall be made to any 
logical blocks on the medium until a format operation (see 5.2) is initiated by an application client. 

A device server shall respond to a MODE SENSE command (see SPC-4) by reporting the length of the logical 
blocks as specified in the BLOCK LENGTH field sent in the last MODE SELECT command that contained a 
mode parameter block descriptor. If no MODE SELECT command with a block descriptor has been received 
then the current block length shall be returned (e.g., if the block length is 512 bytes and a MODE SELECT 
command occurs with the BLOCK LENGTH field set to 520 bytes, any MODE SENSE commands would return 
520 in the BLOCK LENGTH field). To determine the block length at which the logical unit is currently formatted, 
the application client shall use the READ CAPACITY command (see 5.11) rather than the MODE SELECT 
command. 


4.3.6.3 Long LBA mode parameter block descriptor 

Table 106 defines the block descriptor for direct-access block devices used with the MODE SELECT (10) com¬ 
mand and MODE SENSE (10) command when the longlba bit is set to one in the mode parameter header 
(see SPC-4). 


Table 225 — Long LBA mode parameter block descriptor 


Bit 

Byte 

0 


(MSB) 


5 4 3 2 


NUMBER OF BLOCKS 


8 

11 

12 

15 


(MSB) 


Reserved 


BLOCK LENGTH 


0 


(LSB) 


(LSB) 


A device server shall respond to a MODE SENSE command (see SPC-4) by reporting the number of blocks 
specified in the NUMBER OF BLOCKS field sent in the last MODE SELECT command that contained a mode 
parameter block descriptor. If no MODE SELECT command with a mode parameter block descriptor has been 
received then the current number of blocks shall be returned. To determine the number of blocks at which the 
logical unit is currently formatted, the application client shall use the READ CAPACITY command (see 5.11) 
rather than the MODE SELECT command. 


258 


SCSI Commands Reference Manual, Rev. A 




On a MODE SENSE command, the device server may return a value of zero indicating that it does not report 
the number of blocks in the long LBA mode parameter block descriptor. 

If the logical unit does not support changing its capacity by changing the NUMBER OF BLOCKS field using the 
MODE SELECT command (see SPC-4), the value in the NUMBER OF BLOCKS field is ignored. If the device 
supports changing its capacity by changing the NUMBER OF BLOCKS field, then the NUMBER OF BLOCKS 
field is interpreted as follows: 

a) If the NUMBER OF BLOCKS field is set to zero, the logical unit shall retain its current capacity if the block 
length has not changed. If the NUMBER OF BLOCKS field is set to zero and the content of the BLOCK LENGTH 
field (i.e., new block length) is different than the current block length, the logical unit shall be set to its maximum 
capacity when the new block length takes effect (i.e., after a successful FORMAT UNIT command); 

b) If the NUMBER OF BLOCKS field is greater than zero and less than or equal to its maximum capacity, the log¬ 
ical unit shall be set to that number of blocks. If the content of the BLOCK LENGTH field is the same as the current 
block length, the logical unit shall not become format corrupt. This capacity setting shall be retained through power 
cycles, hard resets, logical unit resets, and l_T nexus losses. If the content of the BLOCK LENGTH field is the 
same as the current block length this capacity setting shall take effect on successful completion of the MODE 
SELECT command. If the content of the BLOCK LENGTH field (i.e., new block length) is different than the current 
block length this capacity setting shall take effect when the new block length takes effect (i.e., after a successful 
FORMAT UNIT command); 

c) If the NUMBER OF BLOCKS field is set to a value greater than the maximum capacity of the device and less 
than FFFFFFFF FFFFFFFFh, then the device server shall terminate the MODE SELECT command with CHECK 
CONDITION status with the sense key set to ILLEGAL REQUEST and the additional sense code set to INVALID 
FIELD IN PARAMETER LIST. The logical unit shall retain its previous block descriptor settings; or 

d) If the NUMBER OF BLOCKS field is set to FFFFFFFF FFFFFFFFh, the logical unit shall be set to its maximum 
capacity. If the content of the BLOCK LENGTH field is the same as the current block length, the logical unit shall 
not become format corrupt. This capacity setting shall be retained through power cycles, hard resets, logical unit 
resets, and l_T nexus losses. If the content of the BLOCK LENGTH field is the same as the current block length 
this capacity setting shall take effect on successful completion of the MODE SELECT command. If the content of 
the BLOCK LENGTH field (i.e., new block length) is different than the current block length this capacity setting 
shall take effect when the new block length takes effect (i.e., after a successful FORMAT UNIT command). 

BLOCK LENGTH field 

The BLOCK LENGTH field specifies the length in bytes of each logical block. No change shall be made to any logical 
blocks on the medium until a format operation (see 5.2) is initiated by an application client. 

A device server shall respond to a MODE SENSE command (see SPC-4) by reporting the length of the logical 
blocks as specified in the BLOCK LENGTH field sent in the last MODE SELECT command that contained a 
mode parameter block descriptor. If no MODE SELECT command with a block descriptor has been received 
then the current block length shall be returned (e.g., if the block length is 512 bytes and a MODE SELECT 
command occurs with the BLOCK LENGTH field set to 520 bytes, any MODE SENSE commands would return 
520 in the BLOCK LENGTH field). To determine the block length at which the logical unit is currently formatted, 
the application client shall use the READ CAPACITY command (see 5.11) rather than the MODE SELECT 
command. 
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4.3.7 


Background Control mode page (ICh) 


The Background Control mode page (see table 226) is a subpage of the Informational Exception Control mode 
page (see SPC-4) and provides controls over background operations. The mode page policy (see SPC-4) for 
this subpage shall be shared. 

Table 226 — Background Control mode page 


Bit 

Byte 

7 

6 

5 4 3 2 1 

0 

0 

PS 

SPF(lb) 

PAGE CODE (ICh) 

1 

SUBPAGE CODE (01 h) 

2 

(MSB) 

PAGE LENGTH 


3 


(LSB) 

4 

Reserved 

EN_BMS 

5 

Reserved 

ENPS 

6 

(MSB) 

BUS INTERVAL TIME 


7 


(LSB) 

8 

(MSB) 

PRE-SCAN TIMEOUT VALUE 


9 


(LSB) 

10 


Reserved 


15 




EN BMS (Enable Background Medium Scan) bit 

0 An enable background medium scan (ENBMS) bit set to zero specifies that background medium scan is disabled. 
1 An EN BMS bit set to one specifies that background medium scan operations are enabled. If the ENPS bit is also 
set to one then a background medium scan operation shall not start until after the pre-scan operation is halted or 
completed. 

The BMS interval time shall occur before a background medium scan operation is started. If a background medium scan is 
in progress when the ENJ3MS bit is changed from one to zero, then the medium scan shall be suspended until the 
EN BMS bit is set to one, at which time the medium scan shall resume from the suspended location. 

EN PS (enable pre-scan) bit 

0 An enable pre-scan (EN_PS) bit set to zero specifies that pre-scan is disabled. If a pre-scan operation is in progress 
when EN_PS is changed from a one to a zero then pre-scan is halted. 

1 An EN PS bit set to one specifies that a pre-scan operation is started after the next power on cycle. 

Once this pre-scan has completed, another pre-scan shall not occur unless the EN_PS bit is set to zero, then 
set to one, and another power on cycle occurs. 

BMS INTERVAL TIME field 

The BMS INTERVAL TIME field specifies the minimum time, in hours, between the start of one pre-scan or background 
medium scan operation and the start of the next background medium scan operation. If the current background medium 
scan operation takes longer than the value specified in the BMS INTERVAL TIME field, then the current background medium 
scan or pre-scan continues until completion and the next background medium scan operation starts on completion of the 
current background medium scan or pre-scan. 
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PRE-SCAN TIMEOUT VALUE field 

The PRE-SCAN TIMEOUT VALUE field specifies the maximum time, in hours, for a pre-scan operation to complete. If the 
pre-scan operation does not complete within the specified time then it is halted. A value of zero specifies an unlimited time¬ 
out value. 

4.3.8 Caching Parameters page (08h) 

The Caching Parameters page for MODE SENSE/MODE SELECT defines the parameters that affect the use 
of the cache (see table 227). 

Table 227 — Caching Parameters page (08h) 



PS (Parameter Savable) bit 

The returned Parameter Savable (PS) bit of 1 indicates that page 01 h parameter data is savable. 

1C (Initiator Control) enable bit 

1 When the Initiator Control (1C) enable bit is set to one, adaptive read look-ahead (ARLA) is disabled. 

0 When 1C is set to ZERO, ARLA is enabled. Since Seagate drives covered by this manual never organize the cache 

according to size of segment, but rather by number of segments, this bit is used to enable or disable ARLA (in non- 
Seagate equipment, this might be used to designate cache size). 
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Note. ARLA cannot be disabled in some Seagate drives using the ASAII code. See individual drive’s 
Product Manual, Volume 1. 

ABPF (ABORT PREFETCH) bit 

1 The ABORT PREFETCH (ABPF) bit, when set to one, with the DRA bit equal to zero, requests that the SCSI device 
abort the PREFETCH upon selection. The ABPF set to one takes precedence over the Minimum PREFETCH bytes. 

0 When set to zero, with the DRA bit equal to zero, the termination of any active PREFETCH is dependent upon 
Caching Page bytes 4 through 11 and is operation and/or vendor-specific. 

CAP (Caching Analysis Permitted) bit 

1 The Caching Analysis Permitted (CAP) bit, when set to one, enables caching analysis. 

0 A zero indicates caching analysis is disabled. Caching analysis results are placed in the SCSI logging information 
table, (see Table 196). See individual drive’s Product Manual, Volume 1, SCSI Bus Conditions and Miscellaneous 
Features Supported table. 

DISC (Discontinuity) bit 

1 The Discontinuity (DISC) bit, when set to one, requests that the SCSI device continue the PREFETCH across time 
discontinuities, such as across cylinders or tracks up to the limits of the buffer, or segment, space available for 
PREFETCH. 

0 When set to zero, the DISC requests that prefetches be truncated at time discontinuities. 

SIZE (Size Enable) bit 

1 The Size Enable (SIZE) bit, when set to one, indicates that the Cache Segment Size is to be used to control caching 
segmentation. 

0 When SIZE equals zero, the Initiator requests that the Number of Cache Segments is to be used to control caching 
segmentation. For Seagate drives covered by this manual, SIZE is always zero. 

WCE (Write Cache Enable) bit 

0 SCSI WRITE commands may not return status and completion message bytes until all data has been written to the 
media. 

1 SCSI WRITE commands may return status and completion message bytes as soon as all data has been received 
from the host. 

MF (Multiplication Factor) bit 

0 The Minimum PREFETCH and Maximum PREFETCH fields are interpreted as a number of logical blocks. 

1 Specifies that the target shall interpret the minimum and maximum PREFETCH fields to be specified in terms of a 

scalar number which, when multiplied by the number of logical blocks to be transferred for the current command, 
yields the number of logical blocks for each of the respective types of PREFETCH. 

RCD (READ Cache Disable) bit 

0 SCSI READ commands may access the cache or the media. 

1 SCSI READ commands must access the media. Data cannot come from the cache. 

DEMAND READ RETENTION PRIORITY field 

DEMAND READ RETENTION PRIORITY. The cache replacement algorithm does not distinguish between retention in the 

cache of host-requested data and PREFETCH data. Therefore, this half byte is always 0. 

WRITE RETENTION PRIORITY field 

WRITE RETENTION PRIORITY. The cache replacement algorithm does distinguish between retention in the cache of 

host-requested data and PREFETCH data. Therefore, this half byte is always 0. 

DISABLE PREFETCH TRANSFER LENGTH field 

DISABLE PREFETCH TRANSFER LENGTH. PREFETCH is disabled for any SCSI READ command whose requested 

transfer length exceeds this value. 
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MINIMUM PREFETCH field 

The MINIMUM PREFETCH specifies the minimum number sectors to prefetch, regardless of the delay it may cause to 
other commands. 

MAXIMUM PREFETCH field 

The MAXIMUM PREFETCH specifies the maximum number of logical blocks that may be prefetched. The PREFETCH 
operation may be aborted before the MAXIMUM PREFETCH value is reached, but only if the MINIMUM PREFETCH value 
has been satisfied. 

MAXIMUM PREFETCH CEILING field 

The MAXIMUM PREFETCH Ceiling specifies an upper limit on the number of logical blocks computed as the maximum 
prefetch. If the MAXIMUM PREFETCH value is greater than the MAXIMUM PREFETCH CEILING, the value is truncated to 
the MAXIMUM PREFETCH CEILING value. 

FSW (FORCE SEQUENTIAL WRITE) bit 

1 The Force Sequential Write (FSW) bit, when set to one, indicates that multiple block writes are to be transferred 
over the SCSI bus and written to the media in an ascending, sequential, logical block order. 

0 When the FSW bit equals zero, the target is allowed to reorder the sequence of writing addressed logical blocks in 
order to achieve a faster command completion. 

The Logical Block Cache Segment Size (LBCSS) bit is not used at this time. 

DRA (Disable READ-Ahead) bit 

1 The Disable READ-Ahead (DRA) bit, when set to one, requests that the target not read into the buffer any logical 
blocks beyond the addressed logical block(s). 

0 When the DRA bit equals zero, the target may continue to read logical blocks into the buffer beyond the addressed 
logical block(s). 

NUMBER OF CACHE SEGMENTS byte 

The NUMBER OF CACHE SEGMENTS byte gives the number of segments into which the host requests the drive divide 
the cache. 

CACHE SEGMENT SIZE field 

The CACHE SEGMENT SIZE field indicates the requested segment size in bytes. This manual assumes that the Cache 
Segment Size field is valid only when the Size bit is one. 

NON-CACHE SEGMENT SIZE field 

The NON-CACHE SEGMENT SIZE field, when greater than zero, specifies to the target the number of bytes the initiator 
requests that the target allocate for a buffer function when all other cache segments are occupied by data to be retained. If 
the number is at least one, caching functions in the other segments need not be impacted by cache misses to perform the 
SCSI buffer function. The impact of the NON-CACHE SEGMENT SIZE equal 0 or the same of this field plus the CACHE 
SEGMENT SIZE greater than the buffer size is vendor-specific. 

In addition to the caching control provided by the Caching Mode page, some 10-byte commands contain con¬ 
trol bits DPO and FUA the intent of which is to override the cache page control bits. 

DPO (DISABLE PAGE OUT) bit 

If DPO = 1, the cache replacement algorithm should not replace existing cache data with the current data (if possible). If a 
cache segment must be overwritten, it should be made the LRU. 

FUA (FORCE UNIT ACCESS) bit 

READ: If FUA = 1, the requested data must be read from the media. If cache data which overlaps the request has not yet 
been written to the media, it should be written before the read is allowed to occur. 

WRITE: If FUA = 1, all data must be written to the media before the SCSI operation returns the status and completion mes¬ 
sage bytes. 
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4.3.9 Control mode page (OAh) 

The Control mode page (see table 228) provides controls over SCSI features that are applicable to all device 
types (e.g., task set management and error logging). If a field in this mode page is changed while there is a 
task already in the task set, it is vendor specific whether the old or new value of the field applies to that task. 
The mode page policy (see SPC-4) for this mode page shall be shared, or per l_T nexus. 


Table 228 — Control mode page 


Bit 

Byte 

7 

6 

5 4 

3 

2 

1 

0 

0 

PS 

SPF (Ob) 

PAGE CODE (OAh) 

1 

PAGE LENGTH (OAh) 

2 

TST TMFONLY 

Reserved 

D_SENSE GLTSD 

RLEC 

3 

QUEUE ALGORITHM MODIFIER 

Reserved 

QERR 

DQUE 

Obsolete 

4 

VS 

RAC 

UAJNTLCK_CTRL 

SWP 

RAERP 

Obsolete 

UAAERP 

Obsolete 

EAERP 

Obsolete 

5 

ATO 

TAS 

Reserved 

AUTOLOAD MODE 

6 

(MSB) 

Obsolete formerly 

READY AER HOLDOFF PERIOD 


7 


(LSB) 

8 

(MSB) 

BUSY TIMEOUT PERIOD 


9 


(LSB) 

10 

(MSB) 

EXTENDED SELF-TEST COMPLETION TIME 


11 


(LSB) 


The PS bit, SPF bit, PAGE CODE field, and PAGE LENGTH field are described in 4.3.5. 


TST (task set type) field 

A task set type (TST) field specifies the type of task set in the logical unit (see table 229). 

Table 229 — Task set type (TST) field 


Code 

Description 

000b 

The logical unit maintains one task set for all l_T nexuses 

001b 

The logical unit maintains separate task sets for each l_T nexus 

010b-111b 

Reserved 


Regardless of the mode page policy (see SPC-4) for the Control mode page, the shared mode page policy 
shall be applied to the TST field. If the most recent MODE SELECT changes the setting of this field, then the 
device server shall establish a unit attention condition (see SAM-3) for the initiator port associated with every 
I T nexus except the l_T nexus on which the MODE SELECT command was received, with the additional 
sense code set to MODE PARAMETERS CHANGED. 

TMF ONLY (Allow Task Management Functions Only) bit 

0 The allow task management functions only (TMFONLY) bit set to zero specifies that the device server shall pro¬ 
cess tasks with the ACA task attribute received on the faulted l_T nexus when an ACA condition has been estab- 
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lished (see SAM-3). 

1 A TMF ONLY bit set to one specifies that the device server shall terminate all tasks received on the faulted l_T 
nexus with an ACA ACTIVE status when an ACA condition has been established. 

D SENSE (DESCRIPTOR FORMAT SENSE DATA) bit 

0 A descriptor format sense data (DSENSE) bit set to zero specifies that the device server shall return the fixed for¬ 
mat sense data when returning sense data in the same l_T_L_Q nexus transaction as a CHECK CONDITION sta¬ 
tus. 

1 A D SENSE bit set to one specifies that the device server shall return descriptor format sense data when returning 
sense data in the same l_T_L_Q nexus transaction as a CHECK CONDITION status, except as defined in 2.4.1. 

GLTSD (Global Logging Target Save Disable) bit 

0 A global logging target save disable (GLTSD) bit set to zero specifies that the logical unit implicitly saves, at vendor 
specific intervals, each log parameter in which the TSD bit (see 4.2) is set to zero. 

1 A GLTSD bit set to one specifies that the logical unit shall not implicitly save any log parameters. 

RLEC (Report Log Exception Condition) bit 

1 A report log exception condition (RLEC) bit set to one specifies that the device server shall report log exception con¬ 
ditions as described in 4.2.1. 

0 A RLEC bit set to zero specifies that the device server shall not report log exception conditions. 

QUEUE ALGORITHM MODIFIER field 

The QUEUE ALGORITHM MODIFIER field (see table 230) specifies restrictions on the algorithm used for reordering tasks 

having the SIMPLE task attribute (see SAM-3). 

Table 230 — QUEUE ALGORITHM MODIFIER field 


Code 

Description 

Oh 

Restricted reordering 

1h 

Unrestricted reordering allowed 

2h-7h 

Reserved 

8h - Fh 

Vendor specific 


A value of zero in the QUEUE ALGORITHM MODIFIER field specifies that the device server shall order the processing 
sequence of tasks having the SIMPLE task attribute such that data integrity is maintained for that l_T nexus (i.e., if the 
transmission of new SCSI transport protocol requests is halted at any time, the final value of all data observable on the 
medium shall have exactly the same value as it would have if all the tasks had been given the ORDERED task attribute). 

A value of one in the QUEUE ALGORITHM MODIFIER field specifies that the device server may reorder the processing 
sequence of tasks having the SIMPLE task attribute in any manner. Any data integrity exposures related to task sequence 
order shall be explicitly handled by the application client through the selection of appropriate commands and task attributes. 

QERR (queue error management) field 

The queue error management (QERR) field (see table 231) specifies how the device server shall handle other tasks when 
one task is terminated with CHECK CONDITION status (see SAM-3). The task set type (see the TST field definition in this 
subclause) defines which other tasks are affected. If the TST field equals 000b, then all tasks from all l_T nexuses are 
affected. If the TST field equals 001 b, then only tasks from the same l_T nexus as the task that is terminated with CHECK 
CONDITION status are affected. 
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Table 231 — Queue error management (QERR) field 


Code 

Definition 

00b 

If an ACA condition is established, the affected tasks in the task set shall resume after the ACA condition is 
cleared (see SAM-3). Otherwise, all tasks other than the task that received the CHECK CONDITION status 
shall be processed as if no error occurred. 

01b 

All the affected tasks in the task set shall be aborted when the CHECK CONDITION status is sent. If the 
TAS bit is set to zero, a unit attention condition (see SAM-3) shall be established for the initiator port asso¬ 
ciated with every l_T nexus that had tasks aborted except for the l_T nexus on which the CHECK CONDI¬ 
TION status was returned, with the additional sense code set to COMMANDS CLEARED BY ANOTHER 
INITIATOR. If the TAS bit is set to one, all affected tasks in the task set for l_T nexuses other than the l_T 
nexus for which the CHECK CONDITION status was sent shall be completed with a TASK ABORTED sta¬ 
tus and no unit attention shall be established. For the l_T nexus to which the CHECK CONDITION status is 
sent, no status shall be sent for the tasks that are aborted. 

10b 

Reserved 

11b 

Affected tasks in the task set belonging to the l_T nexus on which a CHECK CONDITION status is 
returned shall be aborted when the status is sent. 


DQUE (Disable Queuing) bit 

A Disable Queuing (DQUE) bit of one indicates that tagged queuing is disabled on the drive. Any pending commands in the 
queue for that l_T_X nexus is aborted. Any subsequent queue tag message received shall be rejected with a MESSAGE 
REJECT message and the I/O process shall be executed as an untagged command. A DQUE bit of zero indicates that 
tagged queuing is enabled, if the drive supports tagged Queuing. 

Note. The DQUE bit has been declared obsolete by the T10 committee. 

TAS (Task Aborted Status) bit 

0 A task aborted status (TAS) bit set to zero specifies that aborted tasks shall be terminated by the device server with¬ 
out any response to the application client. 

1 A TAS bit set to one specifies that tasks aborted by the actions of an I T nexus other than the l_T nexus on which 
the command was received shall be terminated with a TASK ABORTED status (see SAM-3). 

RAC (report a check) bit 

1 The report a check (RAC) bit provides control of reporting long busy conditions or CHECK CONDITION status. A 
RAC bit set to one specifies that the device server should return CHECK CONDITION status rather than returning 
BUSY status if the reason for returning the BUSY status may persist for a longer time than that specified by the 
AUTOLOAD MODE field. 

0 A RAC bit set to zero specifies that the device server may return BUSY status regardless of the length of time the 
reason for returning BUSY status may persist. 

UA INTLCK CTRL (unit attention interlocks control) field 

The unit attention interlocks control (UAJNTLCKCTRL) field (see table 232) controls the clearing of unit attention condi¬ 
tions reported in the same l_T_L_Q nexus transaction as a CHECK CONDITION status and whether returning a status of 
BUSY, TASK SET FULL or RESERVATION CONFLICT results in the establishment of a unit attention condition (see SAM- 
3). 
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Table 232 - 

- Unit attention interlocks control (UA INTLCK CTRL) field 

Code 

Definition 

00b 

The logical unit shall clear any unit attention condition reported in the same l_T_L_Q nexus transaction as 
a CHECK CONDITION status and shall not establish a unit attention condition when a task is terminated 
with BUSY, TASK SET FULL, or RESERVATION CONFLICT status. 

01b 

Reserved a 

10b a 

The logical unit shall not clear any unit attention condition reported in the same l_T_L_Q nexus transaction 
as a CHECK CONDITION status and shall not establish a unit attention condition when a task is terminated 
with BUSY, TASK SET FULL, or RESERVATION CONFLICT status. 

11b a 

The logical unit shall not clear any unit attention condition reported in the same l_T_L_Q nexus transaction 
as a CHECK CONDITION status and shall establish a unit attention condition for the initiator port associ¬ 
ated with the l_T nexus on which the BUSY, TASK SET FULL, or RESERVATION CONFLICT status is 
being returned. Depending on the status, the additional sense code shall be set to PREVIOUS BUSY STA¬ 
TUS, PREVIOUS TASK SET FULL STATUS, or PREVIOUS RESERVATION CONFLICT STATUS. Until it 
is cleared by a REQUEST SENSE command, a unit attention condition shall be established only once for a 
BUSY, TASK SET FULL, or RESERVATION CONFLICT status regardless to the number of commands ter¬ 
minated with one of those status values. 

a A REQUEST SENSE command still clears any unit attention condition that it reports. 


SWP (Software Write Protect) bit 

1 A software write protect (SWP) bit set to one specifies that the logical unit shall inhibit writing to the medium after 
writing all cached or buffered write data, if any. When SWP is one, all commands requiring writes to the medium 
shall be terminated with CHECK CONDITION status, with the sense key set to DATA PROTECT, and the additional 
sense code set to WRITE PROTECTED. When SWP is one and the device type's command standard defines a 
write protect (WP) bit in the DEVICE-SPECIFIC PARAMETER field in the mode parameter header, the WP bit shall 
be set to one for subsequent MODE SENSE commands. 

0 A SWP bit set to zero specifies that the logical unit may allow writing to the medium, depending on other write inhibit 
mechanisms implemented by the logical unit. When the SWP bit is set to zero, the value of the WP bit, if defined, is 
device type specific. For a list of commands affected by the SWP bit and details of the WP bit see the command 
standard for the specific device type. 

The RAERP, UAAERP, and EAERP bits enable specific events to be reported via the asynchronous event 
reporting protocol. When all three bits are zero, the target shall not use asynchronous event reporting. AER is 
defined in SAM-2. These three bits have been declared obsolete by the T10 committee. 

RAERP (Ready AER Permission) bit 

1 A Ready AER Permission (RAERP) bit of one specifies that the target may issue an asynchronous event report 
upon completing its initialization sequence instead of generating a unit attention condition. 

0 A RAERP bit of zero specifies that the target shall not issue an asynchronous event report upon completing its ini¬ 
tialization sequence. 

Note. If the target’s default value for the RAERP bit is one and it does not implement saved parameters 
or include a hardware switch, then it may be impossible to disable the initialization sequence asyn¬ 
chronous event reporting. 

UAAERP (UNIT ATTENTION AER Permission) bit 

1 A UNIT ATTENTION AER Permission (UAAERP) bit of one specifies that the target may issue an asynchronous 
event report instead of creating a unit attention condition upon detecting an unit attention condition event (other than 
upon completing an initialization sequence). 

0 A UAAERP bit of zero specifies that the target shall not issue an asynchronous event reporting instead of creating a 
unit attention condition. 
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EAERP (Error AER Permission) bit 

1 An Error AER Permission (EAERP) bit of one specifies that the target may issue an asynchronous event report 
upon detecting a deferred error condition instead of waiting to report the deferred error on the next command. 

0 An EAERP bit of zero specifies that the target shall not report deferred error conditions via an asynchronous event 
reporting. 

ATO (application tag owner) bit 

1 An application tag owner (ATO) bit set to one specifies that the contents of the LOGICAL BLOCK APPLICATION 
TAG field in the protection information (see SBC-2), if any, shall not be modified by the device server. An ATO bit set 
to zero specifies that the contents of the LOGICAL BLOCK APPLICATION TAG field in the protection information, if 
any, may be modified by the device server. 

0 If the ATO bit is set to zero, the device server shall ignore the contents of the LOGICAL BLOCK APPLICATION TAG 
field in the protection information when received from the application client. 

AUTOLOAD MODE field 

The AUTOLOAD MODE field specifies the action to be taken by a removable medium device server when a medium is 
inserted. For devices other than removable medium devices, this field is reserved. Table 233 shows the usage of the 
AUTOLOAD MODE field. 


Table 233 — AUTOLOAD MODE field 


Code 

Definition 

000b 

Medium shall be loaded for full access. 

001b 

Medium shall be loaded for medium auxiliary memory access only. 

010b 

Medium shall not be loaded. 

011b- 111b 

Reserved 


AUTOLOAD MODE field 

The AUTOLOAD MODE field specifies the maximum time, in 100 milliseconds increments, that the application client allows 
for the device server to return BUSY status for unanticipated conditions that are not a routine part of commands from the 
application client. This value may be rounded down as defined in (see SPC-4 clause 5.4). A OOOOh value in this field is 
undefined by this standard. An FFFFh value in this field is defined as an unlimited period. 

READY AER HOLDOFF PERIOD field 

The READY AER HOLDOFF PERIOD field specifies the minimum time in milliseconds after the target starts its initialization 
sequence that it shall delay before attempting to issue an asynchronous event report. This value may be rounded up. 

Note. This field has been declared obsolete by the T10 committee. 

EXTENDED SELF-TEST COMPLETION TIME field 

The EXTENDED SELF-TEST COMPLETION TIME field contains advisory data that is the time in seconds that the device 
server requires to complete an extended self-test when the device server is not interrupted by subsequent commands and 
no errors occur during processing of the self-test. The application client should expect this time to increase significantly if 
other commands are sent to the logical unit while a self-test is in progress or if errors occur during the processing of the 
self-test. Device servers supporting SELF-TEST CODE field values other than 000b for the SEND DIAGNOSTIC command 
(see 3.43) shall support the EXTENDED SELF-TEST COMPLETION TIME field. The EXTENDED SELF-TEST COMPLE¬ 
TION TIME field is not changeable. 

Bits 0, 1, and 2 of byte 4 as well as bytes 6 and 7 provide controls for the obsolete asynchronous event reporting feature. 
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4.3.10 


Control Extension mode page (OAh) 


The Control Extension mode page (see table 234) is a subpage of the Control mode page (see 4.3.9) and pro¬ 
vides controls over SCSI features that are applicable to all device types. The mode page policy (see SPC-4) for 
this mode page shall be shared. If a field in this mode page is changed while there is a task already in the task 
set, it is vendor specific whether the old or new value of the field applies to that task. 


Table 234 — Control Extension mode page 


Bit 

Byte 

7 

6 

5 4 3 2 1 0 

0 

PS 

SPF (1b) 

PAGE CODE (OAh) 

1 

SUBPAGE CODE (01 h) 

2 

(MSB) 


PAGE LENGTH (ICh) 

3 


(LSB) 

4 

Reserved TCMOS SCSIP IALUAE 

5 

Reserved INITIAL PRIORITY 

6 



Reserved 

31 




The PS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field are described in 
4.3.5. 

SCSIP (SCSI precedence) bit 

1 A SCSI precedence (SCSIP) bit set to one specifies that the timestamp changed using a SET TIMESTAMP com¬ 
mand shall take precedence over methods outside the scope of this standard. 

0 A SCSIP bit set to zero specifies that methods outside this standard may change the timestamp and that the SET 
TIMESTAMP command is illegal. 

TCMOS (Timestamp Changeable By Methods Outside This Standard) bit 

1 A timestamp changeable by methods outside this standard (TCMOS) bit set to one specifies that the timestamp may 
be initialized by methods outside the scope of this standard. 

0 A TCMOS bit set to zero specifies that the timestamp shall not be changed by any method except those defined by 
this standard. 

IALUAE (Implicit Asymmetric Logical Unit Access Enabled) bit 

1 An implicit asymmetric logical unit access enabled (IALUAE) bit set to one specifies that implicit asymmetric logical 
unit access state changes are allowed. 

0 An IALUAE bit set to zero specifies that implicit asymmetric logical unit access state changes be disallowed and 
indicates that implicit asymmetric logical unit access state changes are disallowed or not supported. 

INITIAL PRIORITY field 

The INITIAL PRIORITY field specifies the priority that may be used as the task priority (see SAM-3) for tasks received by 
the logical unit on any l_T nexus (i.e., on any l_T_L nexus) where a priority has not been modified by a SET PRIORITY 
command. If a MODE SELECT command specifies an INITIAL PRIORITY value that is different than the current INITIAL 
PRIORITY, then the device server shall set any priorities that have not be set with a SET PRIORITY command to a value 
different than the new initial priority value to the new priority. The device server shall establish a unit attention condition for 
the initiator port associated with every l_T_L nexus that receives a new priority, with the additional sense code set to PRI¬ 
ORITY CHANGED. 
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4.3.11 Disconnect-Reconnect mode page (02h) 

The Disconnect-Reconnect mode page (see table 235) provides the application client the means to tune the 
performance of the service delivery subsystem. The name for this mode page, disconnect-reconnect, comes 
from the SCSI parallel interface. The mode page policy (see SPC-4) for this mode page shall be shared or per 
target port. If the SCSI target device contains more than one target port, the mode page policy should be per 
target port. 

For Parallel SCSI, see Section 4.3.11 on page 270. 

For Fibre Channel (FC), see Section 4.3.11.2 on page 273. 

For Serial Attached SCSI (SAS), see Section 4.3.11.3 on page 275. 

4.3.11.1 Disconnect-Reconnect mode page for Parallel SCSI 

The Disconnect-Reconnect mode page controls parameters that affect one or more target ports. The parame¬ 
ters that may be implemented are specified in the SCSI transport protocol standard for the target port. 

Table 235 — Disconnect-Reconnect mode page 


Bit 

Byte 

7 

6 

5 4 3 2 1 0 

0 

PS 

SPF (Ob) 

PAGE CODE (02h) 

1 

PAGE LENGTH (OEh) 

2 

BUFFER FULL RATIO 

3 

BUFFER EMPTY RATIO 

4 

(MSB) 



5 


BUS INACTIVITY LIMIT 

(LSB) 

6 

(MSB) 


DISCONNECT TIME LIMIT 

7 


(LSB) 

8 

(MSB) 


CONNECT TIME LIMIT 

9 


(LSB) 

10 

(MSB) 


MAXIMUM BURST SIZE 

11 


(LSB) 

12 

EMDP FAIR ARBITRATION DIMM DTDC 

13 

Reserved 

14 

(MSB) 


FIRST BURST SIZE 

15 


(LSB) 


The parameters for a target port affect its behavior regardless of which initiator port is forming an l_T nexus 
with the target port. The parameters may be accessed by MODE SENSE (see 3.13) and MODE SELECT (see 
3.11) commands directed to any logical unit accessible through the target port. If a parameter value is 
changed, all the device servers for all logical units accessible through the target port shall establish a unit 
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attention condition for the initiator port associated with every l_T nexus that includes the target port except the 
I T nexus on which the MODE SELECT command was received, with the additional sense code set to MODE 
PARAMETERS CHANGED. 

If a parameter that is not appropriate for the specific SCSI transport protocol implemented by the target port is 
non-zero, the command shall be terminated with CHECK CONDITION status, with the sense key set to ILLE¬ 
GAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST 

An interconnect tenancy is a period of time during which a given pair of SCSI ports (i.e., an initiator port and a 
target port) are accessing the interconnect layer to communicate with each other (e.g., on arbitrated intercon¬ 
nects, a tenancy typically begins when a SCSI port successfully arbitrates for the interconnect and ends when 
the SCSI port releases the interconnect for use by other devices). Data and other information transfers take 
place during interconnect tenancies. 

The PS bit, SPF bit, PAGE CODE field, and PAGE LENGTH field are described in 4.3.5. 

BUFFER FULL RATIO field 

The BUFFER FULL RATIO field specifies to the target port how full the buffer should be during read operations prior to 
requesting an interconnect tenancy. Target ports that do not implement the requested ratio should round down to the near¬ 
est implemented ratio. 

BUFFER EMPTY RATIO field 

The BUFFER EMPTY RATIO field specifies to the target port how empty the buffer should be during write operations prior 
to requesting an interconnect tenancy. Target ports that do not implement the requested ratio should round down to the 
nearest implemented ratio. 

The buffer full and buffer empty ratios are numerators of a fractional multiplier that has 256 as its denominator. 
A value of zero indicates that the target port determines when to request an interconnect tenancy consistent 
with the disconnect time limit parameter. These parameters are advisory to the target port. 

Note. As an example, consider a target port with ten 512-byte buffers and a specified buffer full ratio of 
3Fh. The formula is: INTEGER((ratio/256)*number of buffers). Therefore in this example INTE- 
GER((3Fh/256)*10) = 2. During the read operations described in this example, the target port 
should request an interconnect tenancy whenever two or more buffers are full. 

BUS INACTIVITY LIMIT field 

The BUS INACTIVITY LIMIT field specifies the maximum time that the target port is permitted to maintain an interconnect 
tenancy without data or information transfer. If the bus inactivity limit is exceeded, then the target port shall conclude the 
interconnect tenancy, within the restrictions placed on it by the applicable SCSI transport protocol. The contents of the 
DTDC field in this mode page also shall affect the duration of an interconnect tenancy. This value may be rounded as 
defined in SPC-4 clause 5.54. A value of zero specifies that there is no bus inactivity limit. Different SCSI transport proto¬ 
cols define different units of measure for the bus inactivity limit. 

DISCONNECT TIME LIMIT field 

The DISCONNECT TIME LIMIT field specifies the minimum time that the target port shall wait between interconnect tenan¬ 
cies. This value may be rounded. A value of zero specifies that there is no disconnect time limit. Different SCSI transport 
protocols define different units of measure for the disconnect time limit. 

CONNECT TIME LIMIT field 

The CONNECT TIME LIMIT field specifies the maximum duration of a single interconnect tenancy. If the connect time limit 
is exceeded, then the target port shall conclude the interconnect tenancy, within the restrictions placed on it by the applica¬ 
ble SCSI transport protocol. The contents of the DTDC field in this mode page also shall affect the duration of an intercon¬ 
nect tenancy. This value may be rounded. A value of zero specifies that there is no connect time limit. Different SCSI 
transport protocols define different units of measure for the connect time limit. 

MAXIMUM BURST SIZE field 

The MAXIMUM BURST SIZE field indicates the maximum amount of data that the target port shall transfer during a single 
data transfer operation. This value is expressed in increments of 512 bytes (i.e., a value of one means 512 bytes, two 
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means 1 024 bytes, etc.). The relationship, if any, between data transfer operations and interconnect tenancies is defined in 
the individual SCSI transport protocol standards. A value of zero specifies there is no limit on the amount of data trans¬ 
ferred per data transfer operation. 

In terms of the SCSI transport protocol services (see SAM-3), the device server shall limit the Request Byte Count argu¬ 
ment to the Receive Data-Out protocol service and the Send Data-In protocol service to the amount specified in the MAX¬ 
IMUM BURST SIZE field. 

EMDP (Enable Modify Data Pointers) bit 

The enable modify data pointers (EMDP) bit specifies whether or not the target port may transfer data out of order. 

0 If the EMDP bit is set to zero, the target port shall not transfer data out of order. 

1 If the EMDP bit is set to one, the target port is allowed to transfer data out of order. 

FAIR ARBITRATION field 

The FAIR ARBITRATION field specifies whether the target port should use fair or unfair arbitration when requesting an 
interconnect tenancy. The field may be used to specify different fairness methods as defined in the individual SCSI trans¬ 
port protocol standards. 

DIMM (Disconnect Immediate) bit 

0 A disconnect immediate (DIMM) bit set to zero specifies that the target port may transfer data for a command during 
the same interconnect tenancy in which it receives the command. Whether or not the target port does so may 
depend upon the target port’s internal algorithms, the rules of the applicable SCSI transport protocol, and settings of 
the other parameters in this mode page. 

1 A disconnect immediate (DIMM) bit set to one specifies that the target port shall not transfer data for a command 
during the same interconnect tenancy in which it receives the command. 

DTDC (Data Transfer Disconnect Control) field 

The data transfer disconnect control (DTDC) field (see table 236) defines other restrictions on when multiple interconnect 
tenancies are permitted. A non-zero value in the DTDC field shall take precedence over other interconnect tenancy controls 
represented by other fields in this mode page. 


Table 236 — Data transfer disconnect control 


DTDC 

Description 

000b 

Data transfer disconnect control is not used. Interconnect tenancies are controlled by other fields in this 
mode page. 

001b 

All data for a command shall be transferred within a single interconnect tenancy. 

010b 

Reserved 

011b 

All data and the response for a command shall be transferred within a single interconnect tenancy. 

100b-111b 

Reserved 


FIRST BURST SIZE field 

The FIRST BURST SIZE field specifies the maximum amount of data that may be transferred to the target port for a com¬ 
mand along with the command (i.e., the first burst). This value is expressed in increments of 512 bytes (i.e., a value of one 
means 512 bytes, two means 1 024 bytes, etc.). The meaning of a value of zero is SCSI transport protocol specific. SCSI 
transport protocols supporting this field shall provide an additional mechanism to enable and disable the first burst function. 
In terms of the SCSI transport protocol services (see SAM-3), the Receive Data-Out protocol service shall retrieve the 
first FIRST BURST SIZE amount of data from the first burst. 
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4.3.11.2 Disconnect-Reconnect mode page for FCP (02h) 


4.3.11.2.1 Overview and format of Disconnect-Reconnect mode page for FCP 

The Disconnect-Reconnect mode page for FCP (see Table 237) allows the application client to modify the 
behavior of the service delivery subsystem. This subclause specifies the parameters defined by SPC-3 that are 
used by FCP devices and defines how FCP devices interpret the parameters. The application client communi¬ 
cates with the device server to determine what values are most appropriate for a device server. The device 
server communicates the parameter values in this mode page to the target FCP_Port, normally the Fibre 
Channel interface circuitry. This communication is internal to the SCSI target device and FCP device and is 
outside the scope of this standard. If a field or bit contains a value that is not supported by the FCP device, the 
device server shall return CFIECK CONDITION status. The sense key shall be set to ILLEGAL REQUEST and 
the additional sense code set to ILLEGAL FIELD IN PARAMETER LIST. 


Table 237 — Disconnect-Reconnect mode page (02h) 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

PS 

Reserved 

PAGE CODE (02h) 

1 

PAGE LENGTH (OEh) 

2 

BUFFER FULL RATIO 

3 

BUFFER EMPTY RATIO 

4 

(MSB) 

BUS INACTIVITY LIMIT 


5 


(LSB) 

6 

(MSB) 

DISCONNECT TIME LIMIT 


7 


(LSB) 

8 

(MSB) 

CONNECT TIME LIMIT 


9 


(LSB) 

10 

(MSB) 

MAXIMUM BURST SIZE 


11 


(LSB) 

12 

EMDP 

FAA 

FAB 

FAC 

RESTRICT 

ED 

RESTRICTED 

13 

Reserved 

14 

(MSB) 

FIRST BURST SIZE 


15 


(LSB) 


An interconnect tenancy is the period of time when an FCP device owns or may access a shared Fibre Chan¬ 
nel interconnect. For arbitrated loops (see FC-AL-2) and Fibre Channel Class 1 connections, a tenancy typi¬ 
cally begins when an FCP device successfully opens the connection and ends when the FCP device releases 
the connection for use by other device pairs. Data and other information transfers take place during intercon¬ 
nect tenancies. 
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Point-to-point or fabric-attached Class 2 or Class 3 links and many other configurations do not have a concept 
of interconnect tenancy and may perform transfers at any time. 

BUFFER FULL RATIO field 

The BUFFER FULL RATIO field indicates to the device server, during read operations, how full the buffer should be prior to 
requesting an interconnect tenancy. Device servers that do not implement the requested ratio should round down to the 
nearest implemented ratio as defined in SPC-3. FCP devices attached to links that do not have the concept of interconnect 
tenancy shall round the ratio to zero and transmit data in a vendor specific manner. 

The value contained in the BUFFER FULL RATIO field is defined by SPC-3. 

BUFFER EMPTY RATIO field 

The BUFFER EMPTY RATIO field indicates to the device server, during write operations, how empty the buffer should be 
prior to transmitting an FCP_XFER_RDY IU that requests the initiator FCP_Port to send data. Device servers that do not 
implement the requested ratio should round down to the nearest implemented ratio as defined in SPC-3. 

The value contained in the BUFFER EMPTY RATIO field is defined by SPC-3. 

BUS INACTIVITY LIMIT field 

The BUS INACTIVITY LIMIT field indicates the maximum time that the target FCP_Port is permitted to maintain an inter¬ 
connect tenancy without data or information transfer, measured in transmission word increments. If the bus inactivity limit is 
exceeded or if the bus is inactive and the target FCP_Port holding the bus detects that the limit is going to be exceeded, the 
device server shall end the interconnect tenancy. This value may be rounded as defined in SPC-3. A value of zero indicates 
that there is no bus inactivity limit. 

Note. Because of the low overheads associated with initiating and closing bus tenancy on Fibre Channel links, device 
servers should end tenancies immediately upon completing the required transfers. 

The BUS INACTIVITY LIMIT field is not applicable for FCP devices attached to links that do not have the concept of inter¬ 
connect tenancy. 

DISCONNECT TIME LIMIT field 

The DISCONNECT TIME LIMIT field indicates the minimum delay between interconnect tenancies measured in increments 
of 128 transmission words. Target FCP_Ports in configurations having the concept of interconnect tenancy shall delay at 
least this time interval after each interconnect tenancy before beginning arbitration. The device server may round this value 
to any value it prefers. A value of zero indicates that the disconnect time limit does not apply. 

The DISCONNECT TIME LIMIT field is not applicable for FCP devices attached to links that do not have the concept of 
interconnect tenancy. 

CONNECT TIME LIMIT field 

The CONNECT TIME LIMIT field indicates the maximum duration of a single interconnect tenancy, measured in increments 
of 128 transmission words. If the connect time limit is exceeded the device server shall conclude the interconnect tenancy, 
within the restrictions placed on it by the applicable Fibre Channel configuration. The device server may round this value to 
any value it prefers. A value of zero indicates that there is no connect time limit. 

The CONNECT TIME LIMIT field is not applicable for FCP devices attached to links that do not have the concept of inter¬ 
connect tenancy. 

MAXIMUM BURST SIZE field 

The MAXIMUM BURST SIZE field indicates the maximum size of all bytes in an FCP_DATA IU that the target FCP_Port 
shall transfer to the initiator FCP_Port in a single Data-In FCP_DATA IU or request from the initiator FCP_Port in an 
FCP_XFER_RDY IU. This parameter does not affect how much data is transferred in a single interconnect tenancy. This 
value is expressed in increments of 512 bytes (e.g., a value of 1 means 512 bytes, two means 1024 bytes, etc.). The device 
server may round this value down as defined in SPC-3. A value of zero indicates there is no limit on the amount of data 
transferred per data transfer operation. This value shall be implemented by all FCP devices. The initiator FCP_Port and tar¬ 
get FCP_Port may use the value of this parameter to adjust internal maximum buffering requirements. 

EMDP bit 

The enable modify data pointers (EMDP) bit indicates whether or not the target FCP_Port may use the random buffer 
access capability to reorder FCP_DATA lUs for a single SCSI command. If the EMDP bit is set to zero, the target FCP_Port 
shall generate continuously increasing relative offset values for each FCP_DATA IU for a single SCSI command. 
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1 If the EMDP bit is set to one, the target FCP_Port may transfer the FCP_DATA lUs for a single SCSI command in 
any order. 

0 If the EMDP bit is set to zero, data overlay is prohibited even if it is allowed by the state of the PRLI FCP Service 
Parameter page DATA OVERLAY ALLOWED bit. 

The EMDP bit does not affect the order of frames within a Sequence. The enable modify data pointers function is optional 
for all FCP devices. 

For bidirectional commands, the EMDP bit applies independently to the read operation and write operation. If the EMDP bit 
is set to zero, the target FCP_Port shall generate continuously increasing relative offset values for the read operation and 
the write operation, but there is no read operation to write operation or write operation to read operation ordering require¬ 
ment. 

FAA, FAB, FAC bits 

The fairness access (FA) bits, FAA, FAB, and FAC, indicate whether a target FCP_Port attached to an arbitrated loop (see 
FC-AL-2) shall use the access fairness algorithm when beginning the interconnect tenancy. 

An FA bit set to one indicates that the target FCP_Port shall use the access fairness algorithm for the specified frames. An 
FA bit set to zero indicates that the target FCP_Port may choose to not use the access fairness algorithm. The FAA bit con¬ 
trols arbitration when the target FCP__Port has one or more FCP_DATA IU frames to send to an initiator FCP_Port. 

The FAB bit controls arbitration when the target FCP_Port has one or more FCP_XFER_RDY IU frames to send to an initi¬ 
ator FCP_Port. 

The FAC bit controls arbitration when the target FCP_Port has an FCP_RSP IU frame to send to an initiator FCP_Port. If 
the target FCP_Port intends to send multiple frame types, it may choose to not use the access fairness algorithm if any 
applicable FA bit is set to zero. FCP devices attached to links that do not have the concept of interconnect tenancy shall 
ignore the FA bits. The FA bits are optional for all FCP devices. 

FIRST BURST SIZE field 

When the WRITE FCP_XFER_RDY DISABLED bit is negotiated as being set to one in the PRLI FCP Service Parameter 
page, the FIRST BURST SIZE field indicates the maximum amount of all bytes that shall be transmitted in the first 
FCP_DATA IU sent from the initiator FCP_Port to the target FCP_Port. If all data is transmitted in the first IU, no subse¬ 
quent FCP_XFER_RDY lUs shall be transmitted by the target FCP_Port. If the maximum amount of data has been trans¬ 
mitted, but more data remains to be transferred, the target FCP_Port shall request that data with subsequent 
FCP_XFER_RDY lUs. 

When the WRITE FCP_XFER_RDY DISABLED bit is negotiated as being set to zero in the PRLI FCP Service Parameter 
page, the FIRST BURST SIZE field is ignored and permission to transmit data from the initiator FCP_Port to the target 
FCP_Port is managed using FCP_XFER_RDY lUs. For data transmissions from the target FCP_Port to the initiator 
FCP_Port, the FIRST BURST SIZE field is ignored. 

The FIRST BURST SIZE field value is expressed in increments of 512 bytes (e.g., a value of one means 512 bytes, two 
means 1024 bytes). A value of zero indicates that there is no first burst size limit. The FIRST BURST SIZE field shall be 
implemented by all FCP devices that support the WRITE FCP_XFER_RDY DISABLED bit being set to one. The application 
client and device server may use the value of this parameter to adjust internal maximum buffering requirements. 

4.3.11.3 Disconnect-Reconnect mode page for SAS (02h) 

4.3.11.3.1 Disconnect-Reconnect mode page overview 

The Disconnect-Reconnect mode page for SAS (see SPC-4) provides the application client the means to tune 
the performance of the service delivery subsystem. Table 238 defines the parameters which are applicable to 
SSP. If any field in the Disconnect-Reconnect mode page is not implemented, the value assumed for the func¬ 
tionality of the field shall be zero (i.e., as if the field in the mode page is implemented and the field is set to 
zero). 

The application client sends the values in the fields to be used by the device server to control the SSP connec¬ 
tions by means of a MODE SELECT command. The device server shall then communicate the field values to 
the SSP target port. The field values are communicated from the device server to the SSP target port in a ven¬ 
dor-specific manner. 
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SAS devices shall only use the parameter fields defined below in this subclause. If any other fields within the 
Disconnect-Reconnect mode page of the MODE SELECT command contain a non-zero value, the device 
server shall terminate the MODE SELECT command with CHECK CONDITION status with the sense key set 
to ILLEGAL REQUEST and the additional sense code set to INVALID FIELD IN PARAMETER LIST 


Table 238 — Disconnect-Reconnect mode page for SAS 


Bit 

Byte 

7 

6 

5 4 3 2 1 0 

0 

PS 

RESERVED 

PAGE CODE (02h) 

1 

PAGE LENGTH (OEh) 

2 

RESERVED 

3 

RESERVED 

4 

(MSB) 


BUS INACTIVITY TIME LIMIT 

5 


(LSB) 

6 



RESERVED 

7 



8 

(MSB) 


MAXIMUM CONNECT TIME LIMIT 

9 


(LSB) 

10 

(MSB) 


MAXIMUM BURST SIZE 

11 


(LSB) 

12 

RESERVED 

13 

RESERVED 

14 

(MSB) 


FIRST BURST SIZE 

15 


(LSB) 


The PARAMETERS SAVEABLE (PS) bit is defined in SPC-4. 

The PAGE CODE (PS) field shall be set to 02h. 

The PAGE LENGTH field shall be set to OEh. 

BUS INACTIVITY TIME LIMIT field 

The value in the BUS INACTIVITY TIME LIMIT field contains the maximum period that an SSP target port is permitted to 
maintain a connection without transferring a frame to the SSP initiator port. This value shall be the number of 100 pis incre¬ 
ments between frames that the SSP target port transmits during a connection. When this number is exceeded, the SSP tar¬ 
get port shall prepare to close the connection (i.e., by requesting to have the link layer transmit DONE). This value may be 
rounded as defined in SPC-4. A value of zero in this field shall specify that there is no bus inactivity time limit. The bus inac¬ 
tivity time limit is enforced by the port layer. 

MAXIMUM CONNECT TIME LIMIT field 

The value in the MAXIMUM CONNECT TIME LIMIT field contains the maximum duration of a connection. This value shall 
be the number of 100 ps increments that an SSP target port transmits during a connection after which the SSP target port 
shall prepare to close the connection (e.g., a value of one in this field means that the time is less than or equal to 100 ps 
and a value of two in this field means that the time is less than or equal to 200 ps). If an SSP target port is transferring a 
frame when the maximum connection time limit is exceeded, the SSP target port shall complete transfer of the frame before 
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preparing to close the connection. A value of zero in this field shall specify that there is no maximum connection time limit. 
The maximum connection time limit is enforced by the port layer. 

MAXIMUM BURST SIZE field 

For read data, the value in the MAXIMUM BURST SIZE field contains the maximum amount of data that is transferred dur¬ 
ing a connection by an SSP target port per l_T_L_Q nexus without transferring at least one frame for a different l_T_L_Q 
nexus. If the SSP target port: 

a) has read data to transfer for only one l_T_L_Q nexus, and 

b) has no requests to transfer write data for any l_T_L_Q nexus; 

then the SSP target port shall prepare to close the connection after the amount of data specified by the MAXIMUM BURST 
SIZE field is transferred to the SSP initiator port. 

For write data, the value shall specify the maximum amount of data that an SSP target port requests via a single 
XFER_RDY frame. 

This value shall be specified in 512-byte increments (e.g., a value of one in this field means that the number of bytes trans¬ 
ferred to the SSP initiator port for the nexus is less than or equal to 512 and a value of two in this field means that the num¬ 
ber of bytes transferred to the SSP initiator port for the nexus is less than or equal to 1 024). The device server may round 
this value down as defined in SPC-4. A value of zero in this field shall specify that there is no maximum burst size. 

In terms of the SCSI transport protocol services, the device server shall limit the Request Byte Count argument to the 
Receive Data-Out () protocol service and the Send Data-In () protocol service to the amount specified in this field. 


FIRST BURST SIZE field 

If the ENABLE FIRST BURST field in the COMMAND frame is set to zero, the FIRST BURST SIZE field is ignored. 

If the ENABLE FIRST BURST field in the COMMAND frame is set to one, the value in the FIRST BURST SIZE field con¬ 
tains the maximum amount of write data in 512-byte increments that may be sent by the SSP initiator port to the SSP target 
port without having to receive an XFERRDY frame from the SSP target port (e.g., a value of one in this field means that 
the number of bytes transferred by the SSP initiator port is less than or equal to 512 and a value of two in this field means 
that the number of bytes transferred by the SSP initiator port is less than or equal to 1 024). 

Specifying a non-zero value in the FIRST BURST SIZE field is equivalent to an implicit XFER RDY frame for each com¬ 
mand requiring write data where the WRITE DATA LENGTH field of the XFER RDY frame is set to 512 times the value of 
the FIRST BURST SIZE field 

The rules for data transferred using the value in the FIRST BURST SIZE field are the same as those used for data trans¬ 
ferred for an XFER RDY frame (i.e., the number of bytes transferred using the value in the FIRST BURST SIZE field is as 
if that number of bytes was requested by an XFER RDY frame). 

If the amount of data to be transferred for the command is less than the amount of data specified by the FIRST BURST 
SIZE field, the SSP target port shall not transmit an XFER_RDY frame for the command. If the amount of data to be trans¬ 
ferred for the command is greater than the amount of data specified by the FIRST BURST SIZE field, the SSP target port 
shall transmit an XFER RDY frame after it has received all of the data specified by the FIRST BURST SIZE field from the 
SSP initiator port. All data for the command is not required to be transferred during the same connection in which the com¬ 
mand is transferred. 

A value of zero in this field shall specify that there is no first burst size (i.e., an SSP initiator port shall transmit no write 
DATA frames to the SSP target port before receiving an XFER RDY frame). 

The first burst size is handled by the SCSI transport protocol services and the SSP transport layer. 
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4.3.12 


Format Parameters page (03h) 


The Format Parameters page implementation is defined in Table 239. This table summarizes the function and 
defines the default or changeability status for each bit. The actual implementation of reserving spare areas for 
defect management takes place during the FORMAT UNIT command. 

Note. In Table 239, zone refers to defect management zone (one or more tracks), not a ZBR (variable 
track capacity recording) zone.ZBR zones are referred to as notches (page OCh is the Notch page). 

Table 239 — Format Parameters page (03h) 


Bit 

7 

6 

5 

4 

3 

2 

1 

0 

Byte 










Page Descriptor Header 


0 

PS 

Reserved 

PAGE CODE (03h) 

1 

PAGE LENGTH (16h) 


Format Parameters 


2,3 

TRACKS PER ZONE 

4,5 

ALTERNATE SECTORS PER ZONE 

6,7 

ALTERNATE TRACKS PER ZONE 

8,9 

ALTERNATE TRACKS PER VOLUME 

10,11 

SECTORS PER TRACK 

12,13 

DATA BYTES PER PHYSICAL SECTOR 

14,15 

INTERLEAVE 

16,17 

TRACK SKEW FACTOR 

18,19 

CYLINDER SKEW FACTOR 

20 

SSEC HSEC RMB SURF DRIVE TYPE 

21,22,23 

Reserved 


PS (Page Savable) bit 

The only time this page of parameters may be sent is immediately before sending a FORMAT UNIT command to the drive. 
The Current parameters for this page are updated immediately but any changes between these Current parameters and 
the existing media format are not in effect until after the FORMAT UNIT command is completed. A PS bit of 1 indicates this 
page is savable. The PS bit is not used with the MODE SELECT command. 

TRACKS PER ZONE field 

The TRACKS PER ZONE field indicates the number of tracks the drive allocates to each defect management zone. A zone 
can be one or more tracks or one or more cylinders. See individual drive’s Product Manual, Volume 1, for number of tracks 
allocated to each defect management zone for that drive model. 

ALTERNATE SECTORS PER ZONE field 

The ALTERNATE SECTORS PER ZONE field indicates the number of spare sectors to be reserved for the defined defect 
management zone. A value of zero indicates that no sectors are to be reserved in each zone for defect management. This 
is to accommodate hosts that want to manage the defects themselves. 
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ALTERNATE TRACKS PER ZONE field 

The ALTERNATE TRACKS PER ZONE field indicates the number of spare tracks to be reserved at the end of each defect 
management zone. A value of zero indicates that no spare tracks are to be reserved in each zone for defect management 
by the drive. 

ALTERNATE TRACKS PER VOLUME field 

The ALTERNATE TRACKS PER VOLUME field indicates the number of spare tracks to be reserved at the end of the drive 
volume. The drive uses these locations for replacing defective sectors. A value of zero indicates that no spare tracks are to 
be reserved at the end of the unit for defect management. The initiator may change this value for a number between 0 and 
255 that is a multiple of the total number of Data Read/Write heads installed. However, it is not changeable on some prod¬ 
ucts. 

SECTORS PER TRACK field 

The SECTORS PER TRACK field indicates the average number of physical sectors the drive has per disc track. This value 
depends on the selected sector size and ZBR zones. The number of user accessible sectors per track may be fewer than 
the reported value, since sectors per Track includes sectors set aside for defect management. This value cannot be used to 
calculate drive user accessible capacity. 

Note. The value cannot be directly selected with the MODE SELECT command, but is a report of how the 
drive is configured. 

DATA BYTES PER PHYSICAL SECTOR field 

The DATA BYTES PER PHYSICAL SECTOR field indicates the number of data bytes the drive shall allocate per physical 
sector. This value equals the block length reported in the MODE SENSE block descriptor. The bytes per physical sector is 
not directly changeable by the initiator and is not verified on a MODE SELECT command. 

INTERLEAVE field 

The INTERLEAVE field is the interleave value sent to the drive during the last FORMAT UNIT command. 

Note. This field is valid only for MODE SENSE commands. The drive ignores this field during MODE 
SELECT commands. 

TRACK SKEW FACTOR field 

The TRACK SKEW FACTOR field indicates the average number of physical sectors between the last logical block on one 
track and the first logical block on the next sequential track of the same cylinder. A value of zero indicates no skew. 

Note. This value is not changeable by a SCSI initiator port. 

CYLINDER SKEW FACTOR field 

The CYLINDER SKEW FACTOR field indicates the average number of physical sectors between the last logical block of 
one cylinder and the first logical block of the next cylinder. A value of zero indicates no skew. Cylinder skew will be utilized 
by a drive but is not changeable by a SCSI initiator port. 

DRIVE TYPE field 

The DRIVE TYPE field bits are defined as follows: 

a) The Hard Sectoring (HSEC) bit (bit 6) set to one indicates the drive shall use hard sector formatting. 

b) Bits 0-5, and 7 are not implemented by the drive and are always zero. All bits (0-7) are not changeable. 

c) See individual drive’s Product Manual, Volume 1, MODE SENSE Data clause for changeable values. 
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4.3.13 


Informational Exceptions Control mode page (ICh) 


The Informational Exceptions Control mode page (see table 240) defines the methods used by the device 
server to control the reporting and the operations of specific informational exception conditions. This page shall 
only apply to informational exceptions that report an additional sense code of FAILURE PREDICTION 
THRESHOLD EXCEEDED or an additional sense code of WARNING to the application client. The mode page 
policy (see SPC-4) for this mode page shall be shared, or per l_T nexus. 

Informational exception conditions occur as the result of vendor specific events within a logical unit. An infor¬ 
mational exception condition may occur asynchronous to any commands issued by an application client. 

Note. Storage devices that support SMART (Self-Monitoring Analysis and Reporting Technology) for pre¬ 
dictive failure software should use informational exception conditions. 


Table 240 — Informational Exceptions Control mode page 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

PS 

SPF (Ob) 

PAGE CODE (ICh) 

1 

PAGE LENGTH (OAh) 

2 

PERF 

Reserved 

EBF 

EWASC 

DEXCPT 

TEST 

Reserved 

LOGERR 

3 

Reserved 

MRIE 

4 

(MSB) 



INTERVAL TIMER 




7 








(LSB) 

8 

(MSB) 



REPORT COUNT 




11 








(LSB) 


The PS bit, SPF bit, PAGE CODE field, and PAGE LENGTH field are described in 4.3.5. 

LOGERR (Log Error) bit 

If the log errors (LOGERR) bit is set to zero, the logging of informational exception conditions by a device 
server is vendor specific. If the LOGERR bit is set to one, the device server shall log informational exception 
conditions. 

TEST bit 

1 A TEST bit set to one shall create a test device failure at the next interval time, as specified by the INTERVAL 
TIMER field, if the DEXCPT bit is set to zero. When the TEST bit is set to one, the MRIE and REPORT COUNT 
fields shall apply as if the TEST bit were zero. The test device failure shall be reported with the additional sense 
code set to FAILURE PREDICTION THRESHOLD EXCEEDED (FALSE). If both the TEST bit and the DEXCPT bit 
are one, the MODE SELECT command shall be terminated with CHECK CONDITION status, with the sense key set 
to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN PARAMETER LIST. 

0 A TEST bit set to zero shall instruct the device server not to generate any test device failure notifications. 

DEXCPT (Disable Exception Control) bit 

0 A disable exception control (DEXCPT) bit set to zero indicates the failure prediction threshold exceeded reporting 
shall be enabled. The method for reporting the failure prediction threshold exceeded when the DEXCPT bit is set to 
zero is determined from the MRIE field. 

1 A DEXCPT bit set to one indicates the device server shall disable reporting of the failure prediction threshold 
exceeded. The MRIE field is ignored when DEXCPT is set to one and EWASC is set to zero. 
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EWASC (Enable Warning) bit 

0 If the enable warning (EWASC) bit is set to zero, the device server shall disable reporting of the warning. The MRIE 
field is ignored when DEXCPT is set to one and EWASC is set to zero. 

1 If the EWASC bit is set to one, warning reporting shall be enabled. The method for reporting the warning when the 
EWASC bit is set to one is determined from the MRIE field. 

EBF (Enable Background Function) bit 

1 If background functions are supported and the Enable Background Function (EBF) bit is set to one, then the device 
server shall enable background functions. 

0 If the EBF bit is set to zero, the device server shall disable the functions. Background functions with separate enable 
control bits (e.g., background medium scan defined in SBC-3) are not controlled by this bit. 

For the purposes of the EBF bit, background functions are defined as idle time functions that may impact performance that 
are performed by a device server operating without errors but do not impact the reliability of the logical unit (e.g., read 
scan). 

PERF (Performance) bit 

0 If the performance (PERF) bit is set to zero, informational exception operations that are the cause of delays are 
acceptable. 

1 If the PERF bit is set to one, the device server shall not cause delays while doing informational exception opera¬ 
tions. A PERF bit set to one may cause the device server to disable some or all of the informational exceptions 
operations, thereby limiting the reporting of informational exception conditions. 

MRIE (Method Of Reporting Informational Exceptions) field 

The value in the method of reporting informational exceptions (MRIE) field defines the method that shall be 
used by the device server to report informational exception conditions (see table 241). The priority of reporting 
multiple information exceptions is vendor specific. 


Table 241 — Method of reporting informational exceptions (MRIE) field (Sheet 1 of 2) 


MRIE 

Description 

Oh 

No reporting of informational exception condition: The device server shall not report information excep¬ 
tion conditions. 

1h 

Asynchronous event reporting: Obsolete 

2h 

Generate unit attention: The device server shall report informational exception conditions by establishing 
a unit attention condition (see SAM-3) for the initiator port associated with every l_T nexus, with the addi¬ 
tional sense code set to indicate the cause of the informational exception condition. 

As defined in SAM-3, the command that has the CHECK CONDITION status with the sense key set to UNIT 
ATTENTION is not processed before the informational exception condition is reported. 

3h 

Conditionally generate recovered error: The device server shall report informational exception condi¬ 
tions, if the reporting of recovered errors is allowed, a by returning a CHECK CONDITION status. If the 
TEST bit is set to zero, the status may be returned after the informational exception condition occurs on any 
command for which GOOD status or INTERMEDIATE status would have been returned. If the TEST bit is 
set to one, the status shall be returned on the next command received on any l_T nexus that is normally 
capable of returning an informational exception condition when the test bit is set to zero. The sense key 
shall be set to RECOVERED ERROR and the additional sense code shall indicate the cause of the informa¬ 
tional exception condition. 

The command that returns the CHECK CONDITION for the informational exception shall complete without 
error before any informational exception condition may be reported. 

a In some command standards, this is controlled by the post error (PER) bit in the Read-Write Error Recovery mode 
page. 
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Table 241 — Method of reporting informational exceptions (MRIE) field (Sheet 2 of 2) 


MRIE 

Description 

4h 

Unconditionally generate recovered error: The device server shall report informational exception condi¬ 
tions, regardless of whether the reporting of recovered errors is allowed, 3 by returning a CHECK CONDI¬ 
TION status. If the TEST bit is set to zero, the status may be returned after the informational exception 
condition occurs on any command for which GOOD status or INTERMEDIATE status would have been 
returned. If the TEST bit is set to one, the status shall be returned on the next command received on any 
l_T nexus that is normally capable of returning an informational exception condition when the TEST bit is 
set to zero. The sense key shall be set to RECOVERED ERROR and the additional sense code shall indi¬ 
cate the cause of the informational exception condition. 

The command that returns the CHECK CONDITION for the informational exception shall complete without 
error before any informational exception condition may be reported. 

5h 

Generate no sense: The device server shall report informational exception conditions by returning a 
CHECK CONDITION status. If the TEST bit is set to zero, the status may be returned after the informational 
exception condition occurs on any command for which GOOD status or INTERMEDIATE status would have 
been returned. If the TEST bit is set to one, the status shall be returned on the next command received on 
any l_T nexus that is normally capable of returning an informational exception condition when the TEST bit 
is set to zero. The sense key shall be set to NO SENSE and the additional sense code shall indicate the 
cause of the informational exception condition. 


The command that returns the CHECK CONDITION for the informational exception shall com¬ 
plete without error before any informational exception condition may be reported. 

6h 

Only report informational exception condition on request: The device server shall preserve the infor¬ 
mational exception(s) information. To find out about information exception conditions the application client 
polls the device server by issuing a REQUEST SENSE command. The sense key shall be set to NO 

SENSE and the additional sense code shall indicate the cause of the informational exception condition. 

7h - Bh 

Reserved 

Ch-Fh 

Vendor specific 

a In some command standards, this is controlled by the post error (PER) bit in the Read-Write Error Recovery mode 
page. 


The value in the INTERVAL TIMER field is the period in 100 millisecond increments for reporting that an infor¬ 
mational exception condition has occurred. The device server shall not report informational exception condi¬ 
tions more frequently than the time specified by the INTERVAL TIMER field and shall report them after the time 
specified by INTERVAL TIMER field has elaPSed. After the informational exception condition has been 
reported the interval timer shall be restarted. A value of zero or FFFF FFFF FFFF FFFFh in the INTERVAL 
TIMER field indicates that the period for reporting an informational exception condition is vendor specific. 

The value in the REPORT COUNT field is the number of times to report an informational exception condition to 
the application client. A value of zero in the REPORT COUNT field indicates there is no limit on the number of 
times the device server reports an informational exception condition. 

The maintaining of the interval timer and the report counter across power cycles, hard resets, logical unit 
resets, and l_T nexus losses is vendor specific. 
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4.3.14 


Notch page (OCh) 


The Notch page (Table 242) contains parameters for direct access devices that implement a variable number 
of blocks per cylinder and support this page. Each section of the drive with a different number of blocks per cyl¬ 
inder is referred to as a notch. 

Table 242 — Notch page (OCh) 


Bit 

Byte 


(MSB) 


(MSB) 


PS Reserved 


ND LPN 


4 3 2 1 0 


PAGE CODE (OCh) 

PAGE LENGTH (16h) 

Reserved 

Reserved 

MAXIMUM NUMBER OF NOTCHES 

(LSB) 

ACTIVE NOTCH 

(LSB) 

STARTING BOUNDARY 

(LSB) 

ENDING BOUNDARY 

(LSB) 

PAGES NOTCHED 

(LSB) 


PS (Parameter Savable) bit 

The Parameter Savable (PS) bit is only used with the MODE SENSE command. This bit is reserved with the MODE 

SELECT command. A PS bit of one indicates that the drive is capable of saving the page in a non-volatile vendor-specific 

location. 

ND (Notched Drive) bit 

0 A Notched Drive (ND) bit of zero indicates that the device is not notched and that all other parameters in this page 
shall be returned as zero by the drive. 

1 An ND bit of one indicates that the drive is notched. For each supported active notch value, this page defines the 
starting and ending boundaries of the notch. 

LPN (Logical or Physical Notch) bit 

0 A Logical or Physical Notch (LPN) bit of zero indicates that the notch boundaries are based on the physical param¬ 
eters of the drive. The cylinder is considered most significant, the head least significant. 

1 An LPN bit of one indicates that the notch boundaries are based on logical blocks on the drive. 

MAXIMUM NUMBER OF NOTCHES field 

The MAXIMUM NUMBER OF NOTCHES field indicates the maximum number of notches supported by the drive. 
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ACTIVE NOTCH field 


The ACTIVE NOTCH field indicates the notch to which this and subsequent MODE SELECT and MODE SENSE com¬ 
mands shall refer, until the active notch is changed by a later MODE SELECT command. The value of the active notch shall 
be greater than or equal to 0 and less than or equal to the maximum number of notches. An active notch value of zero indi¬ 
cates that this and subsequent MODE SELECT and MODE SENSE commands refer to the parameters that apply across 
all notches. 

STARTING BOUNDARY field 

The STARTING BOUNDARY field indicates the beginning of the active notch or, if the active notch is zero, the beginning 
boundary of the drive. If the LPN bit is one, then the four bytes represent a LOGICAL BLOCK ADDRESS. If the LPN bit is 
zero, then the three most significant bytes shall represent the cylinder number and the least significant byte shall represent 
the head number. When used with the MODE SELECT command, this field is ignored. 

ENDING BOUNDARY field 

The ENDING BOUNDARY field indicates the ending of the active notch or, if the active notch is zero, the ending of the 
drive. If the LPN bit is one, then the four bytes represent LOGICAL BLOCK ADDRESS. If the LPN bit is zero, then the three 
most significant bytes shall represent the cylinder number and the least significant byte shall represent the head number. 
When used with the MODE SELECT command, this field is ignored. 

Each notch shall span a set of consecutive logical blocks on the drive, the notches shall not overlap, and no logical block 
shall be excluded from a notch. 

PAGES NOTCHED field 

The PAGES NOTCHED field is a bit map of the mode page codes that indicates which pages contain parameters that may 
be different for different notches. The most significant bit of this field corresponds to page code 3Fh and the least significant 
bit corresponds to page code OOh. If a bit is one, then the corresponding mode page contains parameters that may be dif¬ 
ferent for different notches. If a bit is zero, then the corresponding mode page contains parameters that are constant for all 
notches. 

See individual drive’s Product Manual, Volume 1, MODE SENSE Data clause, for a table showing codes that 
indicate which of these bits are changeable by the host using the MODE SELECT command. 
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4.3.15 


Power Condition mode page (1Ah) 


The Power Condition mode page provides an application client with methods to control the power condition of 
a logical unit (see 3.12). These methods include: 

a) Specifying that the logical unit transition to a power condition without delay; and 

b) Activating and setting of idle condition and standby condition timers to specify that the logical unit wait for a 

period of inactivity before transitioning to a specified power condition. 

The mode page policy (see 3.11) for this mode page shall be shared. 

When a device server receives a command while in a power condition based on a setting in the Power Condi¬ 
tion mode page, the logical unit shall transition to the power condition that allows the command to be pro¬ 
cessed. If either the idle condition timer or the standby condition timer has been set, then they shall be reset on 

receipt of the command. On completion of the command, the timer(s) shall be started. 

Logical units that contain cache memory shall write all cached data to the medium for the logical unit (e.g.,as a 
logical unit does in response to a SYNCHRONIZE CACHE command as described in SBC-2) prior to entering 
into any power condition that prevents accessing the media (e.g., before a hard drive stoPS its spindle motor 
during transition to the standby power condition). 

The logical unit shall use the values in the Power Condition mode page to control its power condition after a 
power on or a hard reset until a START STOP UNIT command setting a power condition is received. 

Table 243 defines the Power Condition mode page. 


Table 243 — Power Condition mode page 


Bit 

Byte 

7 

6 

5 4 3 2 1 0 

0 

PS 

SPF (OB) 

PAGE CODE (1 Ah) 

1 

PAGE LENGTH (OAh) 

2 

Reserved 

3 

Reserved IDLE STANDBY 

4 

(MSB) 


IDLE CONDITION TIMER 

7 


(LSB) 

8 

(MSB) 


STANDBY CONDITION TIMER 

11 


(LSB) 


The PS bit, SPF bit, PAGE CODE field, and PAGE LENGTH field are described in 4.3.5. 

The IDLE and STANDBY bits specify which timers are active. 

IDLE bit 

1 If the IDLE bit is set to one and the STANDBY bit is set to zero, then the idle condition timer is active and the device 
server shall transition to the idle power condition when the idle condition timer is zero. 

0 If the IDLE bit is set to zero, then the device server shall ignore the idle condition timer. 

STANDBY bit 

0 If the STANDBY bit is set to one and the IDLE bit is set to zero, then the standby condition timer is active and the 
device server shall transition to the standby power condition when the standby condition timer is zero. 

1 If the STANDBY bit is set to zero, then the device server shall ignore the standby condition timer. 

Note. If both the IDLE and STANDBY bits are set to one, then both timers are active and run concurrently. When the idle 
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condition timer is zero the device server shall transition to the idle power condition. When the standby condition 
timer is zero the device server shall transition to the standby power condition. If the standby condition timer is zero 
before the idle condition timer is zero, then the logical unit shall transition to the standby power condition. 

IDLE CONDITION TIMER field 

The value in the IDLE CONDITION TIMER field specifies the inactivity time in 100 millisecond increments that the logical 
unit shall wait before transitioning to the idle power condition when the idle bit is set to one. The idle condition timer is 
expired when: 

a) The IDLE CONDITION TIMER field is set to zero; or 

b) The number of milliseconds specified by the value in the IDLE CONDITION TIMER field times 100 milliseconds 
has elaPSed since the last activity (e.g., processing a command that requires the active power condition or per¬ 
forming a self test). 

STANDBY CONDITION TIMER field 

The value in the STANDBY CONDITION TIMER field specifies the inactivity time in 100 millisecond increments that the log¬ 
ical unit shall wait before transitioning to the standby power condition when the STANDBY bit is set to one. The standby 
condition timer is expired when: 

a) The STANDBY CONDITION TIMER field is set to zero; or 

b) The number of milliseconds specified by the value in the STANDBY CONDITION TIMER field times 100 milli¬ 
seconds has elaPSed since the last activity (e.g., processing any command or performing a self test). 


286 


SCSI Commands Reference Manual, Rev. A 



4.3.16 


Read-Write Error Recovery mode page (01 h) 


The Read-Write Error Recovery mode page (see table 244) specifies the error recovery parameters the device 
server shall use during any command that performs a read or write operation to the medium (e.g., READ com¬ 
mands, WRITE commands, and WRITE AND VERIFY commands). 

Table 244 — Read-Write Error Recovery mode page 


Bit 

Byte 

7 

6 

5 

4 

3 2 

1 

0 

0 

PS 

Reserved 

PAGE CODE (01 h) 

1 

PAGE LENGTH (OAh) 

2 

AWRE 

ARRE 

TB 

RC 

ERROR RECOVERY BITS 

EER PER DTE DCR 

3 

READ RETRY COUNT 

4 

Obsolete 

5 

Obsolete 

6 

Obsolete 

7 

Reserved 

RESTRICTED FOR 
MMC-4 

8 

WRITE RETRY COUNT 

9 

Reserved 

10 

(MSB) 

RECOVERY TIME LIMIT 


11 


(LSB) 


PS (Parameters Savable) bit 

The parameters savable (PS) bit is only used with the MODE SENSE command. This bit is reserved with the MODE 
SELECT command. A PS bit set to one indicates that the device server is capable of saving the mode page in a non-vola¬ 
tile vendor-specific location. 

AWRE (Automatic Write Reallocation Enabled) bit 

0 An automatic write reallocation enabled (AWRE) bit set to zero specifies that the device server shall not perform 
automatic reallocation of defective logical blocks during write operations. 

1 An AWRE bit set to one specifies that the device server shall enable automatic reallocation of defective logical 
blocks during write operations. The automatic reallocation shall be performed only if the device server has the valid 
data (e.g., original data in a buffer or recovered from the medium). The valid data shall be placed in the reallocated 
logical block. The device server shall report any failures that occur during the reallocation operation. Error reporting 
as specified by the error recovery bits (i.e., the EER bit, the PER bit, the DTE bit, and the DCR bit) shall be per¬ 
formed only after completion of the reallocation. See the REASSIGN BLOCKS command (see 3.31) for error proce¬ 
dures. 

ARRE (Automatic Read Reallocation Enabled) bit 

0 An automatic read reallocation enabled (ARRE) bit set to zero specifies that the device server shall not perform 
automatic reallocation of defective logical blocks during read operations. 

1 An ARRE bit set to one specifies that the device server shall enable automatic reallocation of defective logical 
blocks during read operations. All error recovery actions required by the error recovery bits (i.e., the EER bit, the 
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PER bit, the DTE bit, and the DCR bit) shall be processed. The automatic reallocation shall then be performed only 
if the device server successfully recovers the data. The recovered data shall be placed in the reallocated logical 
block. The device server shall report any failures that occur during the reallocation operation. Error reporting as 
specified by the error recovery bits (i.e., the EER bit, the PER bit, the DTE bit, and the DCR bit) shall be performed 
only after completion of the reallocation operation. See the REASSIGN BLOCKS command (see 3.31) for error pro¬ 
cedures. 

TB (Transfer Block) bit 

0 A transfer block (TB) bit set to zero specifies that the device server shall not transfer a logical block to the data-in 
buffer if the logical block is not recovered within the recovery limits specified. 

1 A TB bit set to one specifies that the device server shall transfer a logical block to the data-in buffer before returning 
CHECK CONDITION status if the logical block is not recovered within the recovery limits specified. The data 
returned in this case is vendor-specific. The TB bit does not affect the action taken for recovered data. 

RC (Read Continuous) bit 

0 A read continuous (RC) bit set to zero specifies that error recovery operations that cause delays are acceptable dur¬ 
ing the data transfer. Data shall not be fabricated. 

1 An RC bit set to one specifies the device server shall transfer the entire requested length of data without adding 
delays to perform error recovery procedures. This implies that the device server may send data that is erroneous or 
fabricated in order to maintain a continuous flow of data. The device server shall assign priority to the RC bit over 
conflicting bits within this byte. 

Note. Fabricated data may be data already in a buffer or any other vendor-specific data. The RC bit may 
be used in image processing, audio, or video applications. 

EER (Enable Early Recovery) bit 

1 An enable early recovery (EER) bit set to one specifies that the device server shall use the most expedient form of 
error recovery first. 

0 An EER bit set to zero specifies that the device server shall use an error recovery procedure that minimizes the risk 
of error mis-detection or mis-correction. This bit only applies to data error recovery and it does not affect positioning 
retries. 

Note. An EER bit set to one may imply an increase in the probability of error mis-detection or mis-correc- 
tion. An EER bit set to zero allows the specified retry limit to be exhausted prior to using error cor¬ 
rection codes. 

PER (Post Error) bit 

1 A post error (PER) bit set to one specifies that the device server shall report recovered errors. 

0 A PER bit set to zero specifies that the device server shall not report recovered errors, and the device server shall 

perform error recovery procedures within the limits established by the error recovery parameters. 

DTE (Data Terminate On Error) bit 

1 A data terminate on error (DTE) bit set to one specifies that the device server shall terminate the data-in or data-out 
buffer transfer upon detection of a recovered error. 

0 A DTE bit set to zero specifies that the device server shall not terminate the data-in or data-out buffer transfer upon 
detection of a recovered error. 

DCR (Disable Correction) bit 

1 A disable correction (DCR) bit set to one specifies that ECC shall not be used for data error recovery. 

0 A DCR bit set to zero allows the use of ECC for data error recovery. 
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The combinations of the error recovery bits (i.e., the EER bit, the PER bit, the DTE bit, and the DCR bit) are 
explained in table 245. 


Table 245 — Combined error recovery bit descriptions (Sheet 1 of 3) 


EER 

PER 

DTE 

DCR 

Description 

0 

0 

0 

0 

The device server shall perform the full number of retries as specified in the READ RETRY 
COUNT field for read operations, the WRITE RETRY COUNT field for write operations, and 
the VERIFY RETRY COUNT field (see 4.3.21) for verify operations and shall perform error 
correction in an attempt to recover the data. 

The device server shall not report recovered errors. The device server shall terminate a 
command with CHECK CONDITION status before the transfer count is exhausted only if an 
unrecoverable error is detected. 

If an unrecoverable data error occurs during a read operation, the data in the block with the 
unrecoverable error may or may not be transferred to the data-in buffer depending on the 
setting of the transfer block (TB) bit. 

0 

0 

0 

1 

The device server shall perform the full number of retries as specified in the READ RETRY 
COUNT field for read operations, the WRITE RETRY COUNT field for write operations, and 
the VERIFY RETRY COUNT field (see 4.3.21) for verify operations but shall not perform 
error correction in an attempt to recover the data. 

The device server shall not report recovered errors. The device server shall terminate a 
command with CHECK CONDITION status before the transfer count is exhausted only if an 
unrecoverable error is detected. 

If an unrecoverable data error occurs during a read operation, the data in the block with the 
unrecoverable error may or may not be transferred to the data-in buffer depending on the 
setting of the transfer block (TB) bit. 

0 

0 

1 

0 

Invalid mode. The PER bit shall be set to one if the DTE bit is set to one. 

0 

0 

1 

1 

Invalid mode. The PER bit shall be set to one if the DTE bit is set to one. 

0 

1 

0 

0 

The device server shall perform the full number of retries as specified in the READ RETRY 
COUNT field for read operations, the WRITE RETRY COUNT field for write operations, and 
the VERIFY RETRY COUNT field (see 4.3.21) for verify operations and shall perform error 
correction in an attempt to recover the data. 

The device server shall terminate a command with CHECK CONDITION status before the 
transfer count is exhausted only if an unrecoverable error is detected. 

If an unrecoverable data error occurs during a read operation, the data in the block with the 
unrecoverable error may or may not be transferred to the data-in buffer depending on the 
setting of the transfer block (TB) bit. 

The device server shall return CHECK CONDITION status with the sense key set to 
RECOVERED ERROR at the completion of a command during which any recoverable error 
occurs. The INFORMATION field in the sense data shall contain the LBA of the last recov¬ 
ered error that occurred during the command. 
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Table 245 — Combined error recovery bit descriptions (Sheet 2 of 3) 


EER 

PER 

DTE 

DCR 

Description 

0 

1 

0 

1 

The device server shall perform the full number of retries as specified in the READ RETRY 
COUNT field for read operations, the WRITE RETRY COUNT field for write operations, and 
the VERIFY RETRY COUNT field (see 4.3.21) for verify operations but shall not perform 
error correction in an attempt to recover the data. 

The device server shall terminate a command with CHECK CONDITION status before the 
transfer count is exhausted only if an unrecoverable error is detected. 

If an unrecoverable data error occurs during a read operation, the data in the block with the 
unrecoverable error may or may not be transferred to the data-in buffer depending on the 
setting of the transfer block (TB) bit. 

The device server shall return CHECK CONDITION status with the sense key set to 
RECOVERED ERROR at the completion of a command during which any recoverable error 
occurs. The INFORMATION field in the sense data shall contain the LBA of the last recov¬ 
ered error that occurred during the command. 

0 

1 

1 

0 

The device server shall perform the full number of retries as specified in the READ RETRY 
COUNT field for read operations, the WRITE RETRY COUNT field for write operations, and 
the VERIFY RETRY COUNT field (see 4.3.21) for verify operations and shall perform error 
correction in an attempt to recover the data. 

The device server shall terminate a command with CHECK CONDITION status before the 
transfer count is exhausted if any error, either recoverable or unrecoverable, is detected. 
The INFORMATION field in the sense data shall contain the LBA of the block in error. 

If an unrecoverable data error occurs during a read operation, the data in the block with the 
error may or may not be transferred to the data-in buffer depending on the setting of the 
transfer block (TB) bit. 

0 

1 

1 

1 

The device server shall perform the full number of retries as specified in the READ RETRY 
COUNT field for read operations, the WRITE RETRY COUNT field for write operations, and 
the VERIFY RETRY COUNT field (see 4.3.21) for verify operations but shall not perform 
error correction in an attempt to recover the data. 

The device server shall terminate a command with CHECK CONDITION status before the 
transfer count is exhausted if any error, either recoverable or unrecoverable, is detected. 
The INFORMATION field in the sense data shall contain the LBA of the block in error. 

If an unrecoverable data error occurs during a read operation, the data in the block with the 
error may or may not be transferred to the data-in buffer depending on the setting of the 
transfer block (TB) bit. 
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Table 245 — Combined error recovery bit descriptions (Sheet 3 of 3) 


EER 

PER 

DTE 

DCR 

Description 

1 

0 

0 

0 

The device server shall perform the fewest possible number of retries and perform error 
correction in an attempt to recover the data. 

The device server shall not report recovered errors. The device server shall terminate a 
command with CHECK CONDITION status before the transfer count is exhausted only if an 
unrecoverable error is detected. 

If an unrecoverable data error occurs during a read operation, the data in the block with the 
unrecoverable error may or may not be transferred to the data-in buffer depending on the 
setting of the transfer block (TB) bit. 

1 

0 

0 

1 

Invalid mode. The DCR bit shall be set to zero if the EER bit is set to one. 

1 

1 

0 

0 

The device server shall perform the fewest possible number of retries and perform error 
correction in an attempt to recover the data. 

The device server shall terminate a command with CHECK CONDITION status before the 
transfer count is exhausted only if an unrecoverable error is detected. 

If an unrecoverable data error occurs during a read operation, the data in the block with the 
unrecoverable error may or may not be transferred to the data-in buffer depending on the 
setting of the transfer block (TB) bit. 

The device server shall return CHECK CONDITION status with the sense key set to 
RECOVERED ERROR at the completion of a command during which any recoverable error 
occurs. The INFORMATION field in the sense data shall contain the LBA of the last recov¬ 
ered error that occurred during the command. 

1 

1 

0 

1 

Invalid mode. The DCR bit shall be set to zero if the EER bit is set to one. 

1 

1 

1 

0 

The device server shall perform the fewest possible number of retries and perform error 
correction in an attempt to recover the data. 

The device server shall terminate the command with CHECK CONDITION status before 
the transfer count is exhausted if any error, either recoverable or unrecoverable, is 
detected. The INFORMATION field in the sense data shall contain the LBA of the block in 

error. 

If an unrecoverable data error occurs during a read operation, the data in the block with the 
error may or may not be transferred to the data-in buffer depending on the setting of the 
transfer block (TB) bit. 

1 

1 

1 

1 

Invalid mode. The DCR bit shall be set to zero if the EER bit is set to one. 

If an invalid combination of the error recovery bits is sent by the application client the device server shall terminate the 
MODE SELECT command with CHECK CONDITION status with the sense key set to ILLEGAL REQUEST and the addi¬ 
tional sense code set to INVALID FIELD IN PARAMETER LIST. 


READ RETRY COUNT field 

The READ RETRY COUNT field specifies the number of times that the device server shall attempt its recovery algorithm 
during read operations. 
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WRITE RETRY COUNT field 

The WRITE RETRY COUNT field specifies the number of times that the device server shall attempt its recovery algorithm 
during write operations. 

RECOVERY TIME LIMIT field 

The RECOVERY TIME LIMIT field specifies in milliseconds the maximum time duration that the device server shall use for 
data error recovery procedures. The device server may round this value as described in SPC-4. The limit in this field spec¬ 
ifies the maximum error recovery time allowed for any individual logical block. A RECOVERY TIME LIMIT field set to zero 
specifies that the device server shall use its default value. 

When both a retry count and a recovery time limit are specified, the field that specifies the recovery action of least duration 
shall have priority. 

To disable all types of correction and retries the application client should set the EER bit to zero, the PER bit to one, the 
DTE bit to one, the DCR bit to one, the READ RETRY COUNT field to OOh, the WRITE RETRY COUNT field to OOh, 
and the RECOVERY TIME LIMIT field to OOOOh. 


292 


SCSI Commands Reference Manual, Rev. A 



4.3.17 


Protocol Specific Logical Unit mode page (18h) 


4.3.17.1 Protocol specific parameters 

4.3.17.1.1 Protocol specific parameters introduction 

Some commands use protocol specific information in their CDBs or parameter lists. This subclause describes 
those protocol specific parameters. 

Protocol specific parameters may include a PROTOCOL IDENTIFIER field (see table 246) as a reference for 
the SCSI transport protocol to which the protocol specific parameter applies. 

Table 246 — protocol identifier values 


Protocol 

Identifier 

Description 

Protocol 

Standard 

Oh 

Fibre Channel 

FCP-2 

1h 

Parallel SCSI 

SPI-5 

2h 

SSA 

SSA-S3P 

3h 

IEEE 1394 

SBP-3 

4h 

SCSI Remote Direct Memory Access Protocol 

SRP 

5h 

Internet SCSI (iSCSI) 

iSCSI 

6h 

SAS Serial SCSI Protocol 

SAS 

7h 

Automation/Drive Interface Transport Protocol 

ADT 

8h 

AT Attachment Interface (ATA/ATAPI) 

ATA/ATAPI-7 

9h - Eh 

Reserved 


Fh 

No specific protocol 



The Protocol Specific Logical Unit mode page (see table 247) provides protocol specific controls that are asso¬ 
ciated with a logical unit. 

For Parallel SCSI, see Section 4.3.17 on page 293. 

For Fibre Channel (FC), see Section 4.3.17.2 on page 295. 

For Serial Attached SCSI (SAS), see Section 4.3.17.3 on page 296.. 

Table 247 — Protocol Specific Logical Unit mode page 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

PS 

SPF (Ob) 

PAGE CODE (18h) 

1 

PAGE LENGTH (n-1) 

2 


Reserved 



PROTOCOL IDENTIFIER 


3 



PROTOCOL SPECIFIC MODE PARAMETERS 



n 










During an l_T_L nexus, the Protocol Specific Logical Unit mode page controls parameters that affect both: 
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a) One or more target ports; and 

b) The logical unit. 

The parameters that may be implemented are specified in the SCSI transport protocol standard for the target 
port. The mode page policy (see SPC-4) for this mode page shall be shared or per target port and should be 
per target port. 

The parameters for a target port and logical unit affect their behavior regardless of which initiator port is form¬ 
ing an l_T_L nexus with the target port and logical unit. If a parameter value is changed, the device server shall 
establish a unit attention condition for the initiator port associated with every l_T nexus except the l_T nexus on 
which the MODE SELECT command was received, with the additional sense code set to MODE PARAME¬ 
TERS CHANGED. 

The PS bit, SPF bit, PAGE CODE field, and PAGE LENGTH field are described in 4.3.5. 

The value in the PROTOCOL IDENTIFIER (see table 246) field defines the SCSI transport protocol to which 
the mode page applies. Fora MODE SENSE command (see 3.13), the device server shall set the PROTOCOL 
IDENTIFIER field to one of the values shown in Table 246 to indicate the SCSI transport protocol used by the 
target port through which the MODE SENSE command is being processed. For a MODE SELECT command 
(see 3.11), the application client shall set the PROTOCOL IDENTIFIER field to one of the values shown in 
table 246 indicating the SCSI transport protocol to which the protocol specific mode parameters apply. If a 
device server receives a mode page containing a transport protocol identifier value other than the one used by 
the target port on which the MODE SELECT command was received, then the command shall be terminated 
with CHECK CONDITION status, with the sense key set to ILLEGAL REQUEST, and the additional sense code 
set to INVALID FIELD IN PARAMETER LIST. 
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4.3.17.2 Fibre Channel Logical Unit Control mode page (18h) 


The Fibre Channel Logical Unit Control mode page (see table 248) contains those parameters that select FCP 
logical unit operation options. The implementation of any parameter and its associated functions is optional. 
The mode page follows the MODE SENSE and MODE SELECT command rules specified by SPC-3. 

Table 248 — Fibre Channel Logical Unit Control mode page (18h) 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

PS 

SPF (OB) 

PAGE CODE (18h) 

1 

PAGE LENGTH (06h) 

2 

RESERVED 

PROTOCOL IDENTIFIER (FCP = Oh) 

3 

Reserved 

EPDC 

4 

Reserved 

5 

Reserved 

6 

Reserved 

7 

Reserved 


EPDC (ENABLE PRECISE DELIVERY CHECKING) bit 

1 An ENABLE PRECISE DELIVERY CHECKING (EPDC) bit of one indicates that the logical unit shall use the precise 
delivery function defined by this standard. 

0 When the EPDC bit is set to zero, the logical unit shall not use the precise delivery function and shall ignore the con¬ 
tents of the CRN field in the FCP_CMND IU (see FCP-3 clause 9.2.2.2). 

The EPDC bit is valid for all types of link connections. If the precise delivery function is not supported and the Fibre Chan¬ 
nel Logical Unit Control mode page is supported by the logical unit, the EPDC bit shall be masked as not changeable and 
shall follow the MODE SENSE and MODE SELECT command rules specified by SPC-3. 

If the Fibre Channel Logical Unit Control mode page is not supported by a logical unit, the initiator shall 
assume that the precise delivery function is not supported by that logical unit. 
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4.3.17.3 SAS Protocol-Specific Logical Unit mode page 

The SAS Protocol-Specific Logical Unit mode page (see SPC-4) contains parameters that affect SSP target 
port operation on behalf of the logical unit. 

Table 249 defines the subpages of this mode page. 

Table 249 — SAS Protocol-Specific Logical Unit mode page subpages 


Subpage 

Description 

Reference 

Short page 

Short format 

4.3.17.3.1 

Long page OOh 

Not allowed 

Long page EOh - FEh 

Vendor specific 

Long page FFh 

Return all subpages for the Protocol-Specific Logical Unit mode page SPC-4 

All others 

Reserved 


4.3.17.3.1 Protocol-Specific Logical Unit mode page - short format (18h) 

The mode page policy (see SPC-4) for the Protocol-Specific Logical Unit mode page short format subpage 
shall be either shared or per target port. If a SAS target device has multiple SSP target ports, the mode page 
policy should be per target port. Parameters in this page shall affect all phys in the SSP target port if the mode 
page policy is per target port, and shall affect all SSP target ports in the SAS target device if the mode page 
policy is shared. 


Table 250 defines the format of the page for SAS SSP. 

Table 250 — Protocol-Specific Logical Unit mode page for SAS SSP - short format 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

PS 

SPF (Ob) 

PAGE CODE (18h) 

1 

PAGE LENGTH (06h) 

2 

Reserved 

transport 
layer retries 

PROTOCOL IDENTIFIER (6h) 

3 

Reserved 

4 




Reserved 




7 










The PARAMETERS SAVEABLE (PS) bit is defined in SPC-4. 

The SPF bit shall be set to zero for access to the short format mode page. 

The PAGE CODE field shall be set to 18h. 

The PAGE LENGTH field shall be set to 06h. 

The PROTOCOL IDENTIFIER field shall be set to 6h indicating this is a SAS SSP specific mode page. 

A TRANSPORT LAYER RETRIES bit set to one specifies that the target port shall support transport layer 
retries for XFER RDY and DATA frames for the logical unit as described in SAS-2 Transport Layer. A TRANS¬ 
PORT LAYER RETRIES bit set to zero specifies that transport layer retries shall not be used. 
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4.3.18 


Protocol Specific Port mode page (19h) 


The Protocol Specific Port mode page provides protocol specific controls that are associated with a SCSI port. 
The page_0 format (see table 251) is used for subpage OOh and SUB_PAGE format (see table 252) is used for 
subpages 01 h through FEh. See the SCSI transport protocol standard for definition of the protocol specific 
mode parameters. 


Table 251 — Page_0 format Protocol Specific Port mode page 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

PS 

SPF (Ob) 

PAGE CODE (19h) 

1 

PAGE LENGTH (n-1) 

2 


Reserved 



PROTOCOL IDENTIFIER 


3 



PROTOCOL SPECIFIC MODE PARAMETERS 



n 










Table 252 — Sub_page format Protocol Specific Port mode page 


Bit 

Byte 

7 

6 

5 4 3 2 1 0 

0 

PS 

SPF (1b) 

PAGE CODE (19h) 

1 

SUBPAGE CODE 

2 

(MSB) 


PAGE LENGTH (n-3) 

3 


(LSB) 

4 

Reserved 

5 

Reserved PROTOCOL IDENTIFIER 

6 



PROTOCOL SPECIFIC MODE PARAMETERS 

n 




The Protocol Specific Port mode page controls parameters that affect one or more target ports. The parame¬ 
ters that may be implemented are specified in the SCSI transport protocol standard for the target port. The 
mode page policy (see SPC-4) for this mode page shall be shared or per target port. If the SCSI target device 
contains more than one target port, the mode page policy should be per target port. 

The parameters for a target port affect its behavior regardless of which initiator port is forming an l_T nexus 
with the target port. The parameters may be accessed by MODE SENSE (see 3.13) and MODE SELECT (see 
3.11) commands directed to any logical unit accessible through the target port. If a parameter value is 
changed, the device server for all logical units accessible through the target port shall establish a unit attention 
condition for the initiator port associated with every I T nexus except the l_T nexus on which the MODE 
SELECT command was received, with the additional sense code set to MODE PARAMETERS CHANGED. 

The PS bit, SPF bit, PAGE CODE field, SUBPAGE CODE field, and PAGE LENGTH field are described in 
4.3.5. 

The value in the PROTOCOL IDENTIFIER field (see 4.3.17.1.1) defines the SCSI transport protocol to which 
the mode page applies. For a MODE SENSE command, the device server shall set the PROTOCOL IDENTI¬ 
FIER field to one of the values shown in table 246 to indicate the SCSI transport protocol used by the target 
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port through which the MODE SENSE command is being processed. For a MODE SELECT command, the 
application client shall set the PROTOCOL IDENTIFIER field to one of the values shown in table 278 indicating 
the SCSI transport protocol to which the protocol specific mode parameters apply. If a device server receives a 
mode page containing a transport protocol identifier value other than the one used by the target port on which 
the MODE SELECT command was received, then command shall be terminated with CHECK CONDITION 
status, with the sense key set to ILLEGAL REQUEST, and the additional sense code set to INVALID FIELD IN 
PARAMETER LIST. 

For Parallel SCSI, see Section 4.3.18.1 on page 298. 

For Fibre Channel (FC), see Section 4.3.18.2 on page 305. 

For Serial Attached SCSI (SAS), see Section 4.3.18.3 on page 307. 

4.3.18.1 Port Control Mode page (19h) for Parallel SCSI 

The Port Control Mode page contains the parameters that affect SCSI target port operation options. The page 
shall be implemented by LUN 0 of all SPI SCSI target devices. The page shall not be implemented by logical 
units other than LUN 0. The implementation of any bit and its associated functions is optional. The page follows 
the MODE SENSE/MODE SELECT rules specified by the ANSI SPC-4 standard. 

Each SCSI target port shall maintain an independent set of port control mode page parameters for each SCSI 
initiator port. The parameters saveable bit in the mode page format header returned with MODE SENSE com¬ 
mand shall be set to zero if the long mode page format is being used (i.e., Long bit set to one), indicating the 
parameters are not saved through resets. 

After a MODE SELECT command, parameter settings shall remain in effect until either: 

(a) settings are changed by another MODE SELECT command, 

(b) a logical unit reset of LUN 0 occurs, 

(c) an SDTR negotiation successfully completes, 

(d) a WDTR negotiation successfully completes, or 

(e) a PPR negotiation successfully completes with the HOLD_MCS bit set to zero. 


Table 253 — Port Control Mode page short format (19h) 


Bit 

Byte 

7 

6 

5 4 3 2 1 0 

0 

PS 

Long (0) 

PAGE CODE (19h) 

1 

PAGE LENGTH (06h) 

2 

Reserved PROTOCOL IDENTIFIER (1 h) 

3 

Reserved 

4 

(MSB) 


SYNCHRONOUS TRANSFER TIMEOUT 

5 


(LSB) 

6 

Reserved 

7 

Reserved 


PS (Parameter Savable) bit 

The Parameter Savable (PS) bit of 0 indicates that the page 19h parameter data is not savable in non-volatile memory. 
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PROTOCOL IDENTIFIER field 


The PROTOCOL IDENTIFIER field value of 1 h indicates that this mode page applies to a SPI SCSI device. See the SPC-4 
standard for other port control page protocol identifiers. 

SYNCHRONOUS TRANSFER TIMEOUT field 

The SYNCHRONOUS TRANSFER TIMEOUT field indicates the maximum amount of time in 1 ms increments that the 
SCSI target port shall wait before generating an error by doing an unexpected bus free. The SCSI target port shall only go 
to a BUS FREE phase if one of the following events causes the timer, once started, to not reset or reload before expiring. 

a) If there is a REQ transition when there are no outstanding REQs waiting for an ACK then load and start the 
timer. 

b) If there is a REQ transition when there are any outstanding REQs waiting for an ACK then there is no effect on 
the timer. 

c) If there is an ACK transition when there are outstanding REQs waiting for an ACK then load and start the timer. 

d) If, after an ACT transition, there are no outstanding REQs waiting for an ACK then stop the timer. 

A SYNCHRONOUS TRANSFER TIMEOUT field value of OOOOh indicates that the function is 
disabled. 

A value of FFFFh indicates an unlimited period. 


Table 254 — Port Control Mode page long format (19h) 


Bit 

Byte 

7 

6 

5 4 3 2 1 0 

0 

PS 

Long (1) 

PAGE CODE (19h) 

1 

SUBPAGE CODE 

2 

(MSB) 


PAGE LENGTH (n - 3) 

3 


(LSB) 

4 

Reserved 

5 

Reserved PROTOCOL IDENTIFIER = 1h 

6 



PROTOCOL-SPECIFIC MODE PARAMETERS 

n 




The Parameter Savable (PS) bit of 0 indicates that the page 19h parameter data is not savable in non-volatile memory. 

The SUBPAGE CODE field indicates which subpage is being accessed. If the SUBPAGE CODE field is zero, the SCSI tar¬ 
get device shall return a CHECK CONDITION status. The sense key shall be set to ILLEGAL REQUEST and the additional 
sense code set to ILLEGAL FIELD IN PARAMETER LIST. 


Subpage 

Code 

1 

2 

3 

4 


Description 

Margin control subpage 

Saved training configuration values subpage 

Negotiated settings subpage 

Report transfer capabilities subpage 


Reference 

clause 

4.3.18.1.1 

4.3.18.1.2 

4.3.18.1.3 

4.3.18.1.4 


The PROTOCOL IDENTIFIER field value of 1 h indicates that this mode page applies to a SPI SCSI device. See the SPC-4 
standard for other port control page protocol identifiers. 
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4.3.18.1.1 


Margin control subpage 


The margin control subpage contains parameters that set and report margin control values for usage between 
the SCSI initiator/target port pair on subsequent synchronous and paced transfers. 

A MODE SENSE command shall return the current settings for the SCSI initiator/target port pair. Fields that 
are not implemented shall be reported as zero. 

Note. The default value of each margin control field should be 0000b. 

The margin control fields indicate absolute conditions centered around their default values. Absolute conditions 
means that the previous history of the parameter has no relevance to the value of the parameter. 

The maximum supported setting for each field is 0111b and the minimum supported setting for each field is 
1000b. Up to 16 distinct values are available for each field, representing monotonically changing device 
response. Devices that support fewer than 16 distinct values for a field should round non-supported settings to 
a supported value. 

The actual response of a SCSI device to a field value is vendor-specific and calibration of the actual minimum 
and maximum responses to different field values is not defined in this manual or the ANSI SPI-4 specification. 
Margin control settings should not cause the driver to violate SPI-4 specification electrical limits. Margin control 
settings should affect only the REQUEST, ACKNOWLEDGE, DATA BUS, P_CRCA, and DB(P1) signals and 
should affect all of these signals driven by the device by the same amount. 


The margin control fields contain two’s complement values as shown in the table below. 


Value 

Parameter values 

Binary 

Decimal 

0111b 

7 

Maximum setting 

0110b 

6 


0101b 

5 


0100b 

4 


0011b 

3 


0010b 

2 


0001b 

1 


000b 

0 

Recommended default value 

111b 

-1 


1110b 

-2 


1101b 

-3 


1100b 

-4 


1011b 

-5 


1010b 

-6 


1001b 

-7 


1000b 

-8 

Minimum setting 
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Table 255 — Margin control subpage 


Bit 

Byte 

7 6 5 4 

3 2 10 

0 

Reserved 

1 

DRIVER STRENGTH 

Reserved 

2 

DRIVER ASYMMETRY 

DRIVER PRECOMPENSATION 

3 

DRIVER SLEW RATE 

Reserved 

4 

Reserved 

5 

Reserved 

6 

Reserved 

7 

VENDOR-SPECIFIC 

8 

15 

Reserved 


DRIVER STRENGTH field 

The DRIVER STRENGTH field indicates the relative amount of driver source current used by the driver (see clause 7.3.2 in 
the ANSI SPI-4 specification). The DRIVER STRENGTH field affect both the strong and weak drivers. A larger value indi¬ 
cates more driver source current. 

DRIVER ASYMMETRY field 

The DRIVER ASYMMETRY field indicates the relative difference between the amplitudes of asserted and negated signals 
launched from the driver. A larger value indicates a relatively stronger asserted signal compared to the negated signal. 

DRIVER PRECOMPENSATION field 

The DRIVER PRECOMPENSATION field indicates the relative difference between the weak driver and the strong driver 
amplitudes when pre-compensation is enabled. A larger value indicates a larger difference between the weak and strong 
amplitudes. 

DRIVER SLEW RATE field 

The DRIVER SLEW RATE field indicates the relative difference between the assertion and negation magnitudes divided by 
the rise or fall time. A larger value indicates a faster slew rate. 
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4.3.18.1.2 Saved training configuration values subpage 

The saved training configuration values subpage is used to report the SCSI device’s saved training configura¬ 
tion values. These vendor-specific values are maintained by the SCSI device when the retain training informa¬ 
tion option is enabled. The fields are listed in Table 256 however the content of the field is vendor-specific. 

Only values for the current l_T nexus are reported. 

Table 256 — Saved training configuration values subpage 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

Reserved 

3 


4 

MSB DB(0) Value 

7 

LSB 




64 

MSB DB(15) Value 

67 

LSB 

68 

MSB P C RCA Value 

71 

LSB 

72 

MSB PI Value 

75 

LSB 

76 

MSB BSY Value 

79 

LSB 

80 

MSB SEL Value 

83 

LSB 

84 

MSB RST Value 

87 

LSB 

88 

MSB REQ Value 

91 

LSB 

92 

MSB ACK Value 

95 

LSB 

96 

MSB ATN Value 

99 

LSB 

100 

MSB C/D Value 

103 

LSB 
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4.3.18.1.3 Negotiated settings subpage 

The negotiated setting subpage is used to report the negotiated settings of a SCSI target port for the current 
LT nexus. 

Table 257 — Negotiated settings subpage 


Bit 

Byte 

7 6 5 4 

3 2 

1 

0 

0 

TRANSFER PERIOD FACTOR 

1 

Reserved 

2 

REQ/ACK OFFSET 

3 

TRANSFER WIDTH EXPONENT 

4 

Reserved PROTOCOL OPTIONS BITS 

5 

Reserved 

TRANSCEIVER MODE 

SENT 

PCOMPEN 

RECEIVED 

PCOMEN 

6 

Reserved 

7 

Reserved 


TRANSFER PERIOD FACTOR field 

The TRANSFER PERIOD FACTOR field indicates the negotiated transfer period factor for the current l_T nexus. 

REQ/ACK OFFSET field 

The REQ/ACK OFFSET field indicates the negotiated REQ/ACK offset for the current l_T nexus. 

TRANSFER WIDTH EXPONENT field 

The TRANSFER WIDTH EXPONENT field indicates the negotiated transfer width exponent for the current l_T nexus. 

PROTOCOL OPTIONS BITS field 

The PROTOCOL OPTIONS BITS field contains the negotiated protocol options for the current l_T nexus. 

RECEIVED PCOMPEN bit 

The RECEIVED PCOMP_EN bit contains the value of the PCOMP EN bit received by the SCSI target port for the current 
I T nexus. 

SENT PCOMP EN bit 

The SENT PCOMP EN bit contains the value of the PCOMP EN bit sent by the SCSI target port for the current I T nexus. 

TRANSCEIVER MODE field 

The TRANSCEIVER MODE field specifies the current bus mode of the SCSI target port as defined below. 


Code 

Bus mode 

00b 

Unknown (e.g., device not capable of reporting bus mode) 

01b 

Single-ended 

10b 

Low Voltage Differential 

11b 

High Voltage Differential 
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4.3.18.1.4 Report transfer capabilities subpage 

The Report transfer capabilities subpage is used to report the transfer capabilities for the SCSI target port. The 
values in this subpage are not changeable via a MODE SELECT command. 

Table 258 — Report transfer capabilities subpage 


Bit 

Byte 

7 6 5 4 3 2 1 0 

0 

MINIMUM TRANSFER PERIOD FACTOR 

1 

Reserved 

2 

MAXIMUM REQ/ACK OFFSET 

3 

MAXIMUM TRANSFER WIDTH EXPONENT 

4 

PROTOCOL OPTIONS BITS SUPPORTED 

5 

Reserved 

6 

Reserved 

7 

Reserved 


MINIMUM TRANSFER PERIOD FACTOR byte 

The MINIMUM TRANSFER PERIOD FACTOR field shall be set to the smallest value of the transfer period factor supported 
by the SCSI target port. 

MAXIMUM REQ/ACK OFFSET byte 

The MAXIMUM REQ/ACK OFFSET shall be set to the largest value of the REQ/ACK offset supported by the SCSI target 
port. 

MAXIMUM TRANSFER WIDTH EXPONENT byte 

The MAXIMUM TRANSFER WIDTFI EXPONENT field shall be set to the largest value of the transfer width exponent sup¬ 
ported by the SCSI target port. 

PROTOCOL OPTIONS BITS SUPPORTED byte 

The SCSI target port shall set the bits in the PROTOCOL OPTIONS BITS SUPPORTED field to indicate the protocol 
options supported by the SCSI target port. 

4.3.18.2 Port Control Mode page (19h) for Fibre Channel (FC) 

The Fibre Channel Interface Control page controls options relevant to Fibre Channel protocol. It is intended for 
the control of features unique to Fibre Channel protocol that are not suitable for control by login or other tech¬ 
niques defined for Fibre Channel. 

Both the current and saved values of Mode page 19h, byte 3, are changeable using the Mode Select com¬ 
mand. When the saved value of Byte 3 is changed, a new value is stored in nonvolatile (flash) memory, not on 
disc, and is reported during a Mode Sense command when either the current or saved value is requested. 

The current value of Byte 3 may be modified using Mode Select command any number of times. The saved 
value of Byte 3 may be modified using the Mode Select command up to 32 times. After 32 modifications, addi¬ 
tional attempts to modify will result in a response of Illegal Request (05) with Error Code of 2600 (Invalid field in 
parameter list) and the Sense Key pointing to byte 3 as the offending parameter. Additional updates of Byte 3 
saved value may be accomplished by downloading new microcode that supports Fibre Channel Interface Con¬ 
trol page 19h. After a download, the saved value of Byte 3 may be updated 31 more times or 32 times if the 
value is 0 at the time of download. 
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The saved and current value of Byte 3 is preserved through the download. 

Table 259 — Fibre Channel Interface Control page (19h) 


Bit 

Byte 

7 

6 

5 4 

3 2 10 

0 

PS 

SPF (Ob) 

PAGE CODE (19h) 

1 

1 PAGE LENGTH (06h) 

2 

Reserved 

PROTOCOL IDENTIFIER (FCP = Oh) 

3 

DTFD PLPB DDIS DLM 

DSA ALWLI DTIPE DTOLI 

4 

Reserved 

5 

Reserved 

6 

Reserved 

7 

SEQUENCE INITIATIVE RESOURCE RECOVERY TIMEOUT VALUE (RR_TOVSEQ_INIT) 


PS (Parameter Savable) 

This bit is only used with the Mode Sense command. This bit is not used with the Mode Select command. 

1 The drive is capable of saving the page in a nonvolatile vendor-specific location. 

SPF bit 

The SPF field shall be set to zero for access to the short format mode page. 

Page Length byte 

The length of the Fibre Channel Interface Control page in bytes (06h). If the allocation length is too small to transfer all of 
the page, the page length is not adjusted to reflect the truncation. 

DTFD (Disable Target Fabric Discovery) 

1 The target attached by an FC-AL loop will not recognize the presence of a fabric loop port (FL_Port) on the loop. 

The target will only perform the private loop functions defined for FC-PLDA targets. 

0 The target attached by an FC-AL loop will discover the FL_Port if present on the loop and will perform the public 
loop functions defined for FC-FLA targets. Targets attached to an N Port or to an F_Port will ignore this bit. 

PLPB (Prevent Loop Port Bypass) 

1 The target ignores any Loop Port Bypass (LPB) and Loop Port Enable (LPE) primitive sequences. The loop port 
remains enabled. 

Note. Do not set the PLPB bit to one (1) and the DTIPE bit to one (1) at the same time as this is an illegal bit combina¬ 
tion. When an illegal bit combination is sent by the application client, the device server returns Check Condition 
status and sets the sense key to Illegal Request with the additional sense code set to Invalid Field in the Parame¬ 
ter List. 

0 The target allows the Loop Port Bypass and Port Bypass Enable primitive sequences to control the port bypass cir¬ 
cuit. 

DDIS (Disable Discovery) 

1 The target does not require receipt of Address or Port Discovery ELS following loop initialization. The target 
resumes processing of tasks upon completion of loop initialization. 

The target must wait to receive an Address or Port Discovery ELS before it resumes processing tasks for that initiator. 

DLM (Disable Loop Master) 

1 Indicates that a target attached to an FC-AL-2 loop shall not participate in loop master arbitration and shall not 
become loop master. The target shall only repeat LISM frames it receives. 

0 The target may participate in loop master arbitration in the normal manner and, if successful, may become loop 
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master during the loop initialization process. Targets not attached to an arbitrated loop shall ignore the DLM bit. 

REQUIRE HARD ADDRESS (RHA) bit - formerly DSA bit 

If the REQUIRE HARD ADDRESS (RHA) bit is set to one, a target FCP_Port attached to an arbitrated loop (see FCAL-2) 
shall only attempt to obtain its hard address available in the SCA-2 connector (see SFF-8067) or device address jumpers 
during loop initialization. The target FCP_Port shall not attempt to obtain an address during the LISA phase of initialization 
(see FC-AL-2). If there is a conflict for the hard address selection during loop initialization or the target FCP_Port does not 
have a valid hard address available, the target FCP_Port shall enter the nonparticipating state. If the target FCP_Port 
detects loop initialization while in the nonparticipating state, the target FCP_Port shall again attempt to get its hard address. 
If the hard address has not changed from the address obtained in a previous successful loop initialization, the target 
FCP_Port shall attempt to obtain the address in the UFA phase if a valid Fabric Login exists or LI PA phase of loop initializa¬ 
tion. If the hard address has changed, the target FCP_Port shall attempt to obtain the new address in the LIHA phase. 

If the RHA bit is set to zero, the target FCP_Port follows the normal initialization procedure, including the possibility of 
obtaining a soft address during the loop initialization process. 

Target FCP_Ports not attached to an arbitrated loop shall ignore the RHA bit. 

DSA (Disable Soft Address) 

1 The target does not select a soft address if there is a conflict for the SelectJD address available in the SCA connec¬ 
tor during loop initialization. If there is a SelectJD address conflict, the target enters the non-participation state. If 
the target detects loop initialization while in the non-participation state, the target again attempts to get the SelectJD 
address. 

0 The target attempts to obtain a soft address during loop initialization if the SelectJD address is not available or if the 
SelectJD address indicates the use of a soft address (7Fh). 

If ESI activity is underway when the request for the hard address is received, the drive shall use the last known value of the 
hard address before the current ESI activity started. 

ALWLI (Allow Login Without Loop Initialization) 

1 The target uses the SelectJD address available in the SCA connector and accepts logins without verifying the 
address with loop initialization. 

0 The target must verify the address through loop initialization before accepting a login. 

DTIPE (Disable Target Initiated Port Enable) 

1 The target waits for an initiator to send the Loop Port Enable primitive before inserting itself into the loop. The target 
uses the SelectJD address available in the SCA connector to determine if primitives are addressed to it. 

Note. Do not set the PLPB bit to one (1) and the DTIPE bit to one (1) at the same time as this is an illegal 
bit combination. When an illegal bit combination is sent by the application client, the device server 
returns Check Condition status and sets the sense key to Illegal Request with the additional sense 
code set to Invalid Field in the Parameter List. 

0 After completing self test, the target enables the port in the loop without waiting for a Loop Port Enable primitive. 

DTOLI (Disable Target Originated Loop Initialization) 

1 The target does not originate the initializing LIP following insertion into the loop. The target responds to an Initializ¬ 
ing LIP when it is received. The target originates the Loop Failure LIP if it detects loop failure at its input. The target 
originates the Initializing LIP when the loop failure is corrected. 

0 After completing self test, the target originates the Initializing LIP when it enables a port in a loop. 

4.3.18.3 Protocol Specific Port Mode page (19h) for Serial Attached SCSI (SAS) 

4.3.18.3.1 Protocol-specific Port mode page overview 

The Protocol-Specific mode page (see SPC-4) contains parameters that affect SSP target port operation. If the 
mode page is implemented, all logical units in SCSI target devices in SAS domains supporting the MODE 
SELECT or MODE SENSE commands shall implement the page. 

If a SAS target device has multiple SSP target ports, changes in the short page parameters for one SSP target 
port should not affect other SSP target ports. 
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Table 260 defines the subpages of this mode page. 

Table 260 — Protocol-Specific Port mode page subpages 


Subpage 

Description 

Reference 

Short page 

Short format 


Long page OOh 

Not allowed 


Long page 01 h 

Phy Control and Discover subpage 


Long page EOh - FEh 

Vendor specific 


Long page FFh 

Return all subpages for the Protocol-Specific 
Port mode page 

SPC-4 

All others 

Reserved 



4.3.18.3.2 Protocol-Specific Port mode page - short format 

The mode page policy (see SPC-4) for the Protocol-Specific mode page short format subpage shall be either 
shared or per target port. If a SAS target device has multiple SSP target ports, the mode page policy should be 
per target port. 

Parameters in this page shall affect all phys in the SSP target port if the mode page policy is per target port, 
and shall affect all SSP target ports in the SAS target device if the mode page policy is shared. 

Table x defines the format of the page for SAS SSP. 

Table 261 — Protocol-Specific Port mode page for SAS SSP - short format 


Bit 

Byte 

7 

6 

5 

4 

3 2 10 

0 

PS 

PSF (OB) 

PAGE CODE (19h) 

1 

2 

PAGE LENGTH (06h) 

Reserved 

READY 
LED MEAN¬ 
ING 

PROTOCOL IDENTIFIER (6h) 

3 

Reserved 

4 

5 

(MSB) l_T NEXUS LOSS TIME 

(LSB) 

6 

7 

(MSB) INITIATOR RESPONSE TIMEOUT 

(LSB) 


The PARAMETERS SAVEABLE (PS) bit is defined in SPC-4. 

The SPF field shall be set to zero for access to the short format mode page. 

The PAGE CODE field shall be set to 19h. 

The PAGE LENGTH field shall be set to 06h. 

The READY LED MEANING bit specifies the READY LED signal behavior (see 10.4.1). Regardless of the mode page pol¬ 
icy (see SPC-4) for this mode page, the shared mode page policy shall be applied to the READY LED MEANING bit. 
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The PROTOCOL IDENTIFIER field shall be set to 6h indicating this is a SAS SSP specific mode page. 

The l_T NEXUS LOSS TIME field contains the time that the SSP target port shall retry connection requests to an SSP initi¬ 
ator port that are rejected with responses indicating the SSP initiator port may no longer be present before recognizing an 
I T nexus loss. Table 152 defines the values of the l_T NEXUS LOSS TIME field. If this mode page is not implemented, the 
I T nexus loss time is vendor specific. This value is enforced by the port layer. 


Code 

Description 

OOOOh 

Vendor-specific amount of time. 

0001 h to FFFEh 

Time in milliseconds. 

FFFFh 

The SSP target port shall never recognize an l_T nexus loss (i.e., it shall retry the connection 
requests forever). 


Note. If this mode page is implemented, the default value of the l_T NEXUS LOSS TIME field should be non-zero. It 
is recommended that this value be 2 000 ms. 

The INITIATOR RESPONSE TIMEOUT field contains the time in milliseconds that the SSP target port shall 
wait for the receipt of a frame (e.g., a write DATA frame) before aborting the command associated with that 
frame. An INITIATOR RESPONSE TIMEOUT field value of zero indicates that the SSP target port shall disable 
the initiator response timeout timer. If this mode page is not implemented, the logical unit shall not implement 
an initiator response timeout timer. This value is enforced by the transport layer. 
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4.3.18.3.3 


Protocol-Specific Port mode page - Phy Control And Discover subpage (19h) 


The Phy Control And Discover subpage contains phy-specific parameters. The mode page policy (see SPC-4) 
for this subpage shall be shared. Parameters in this subpage shall affect only the referenced phy. 

Table 262 defines the format of the subpage for SAS SSP. 

Table 262 — Protocol-Specific Port mode page SAS SSP - Phy Control And Discover subpage 


Bit 

Byte 

7 

6 

5 4 3 2 1 0 

0 

PS 

SPF (IB) 

PAGE CODE (19h) 

1 

SUBPAGE CODE (01 h) 

2 

3 

(MSB) PAGE LENGTH (N - 3) 

(LSB) 

4 

Reserved 

5 

Reserved PROTOCOL IDENTIFIER (6h) 

6 

Reserved 

7 

NUMBER OF PHYS 


SAS phy mode descriptor list 


8 

FIRST SAS PHY MODE DESCRIPTOR (SEE TABLE 263) 

... 



LAST SAS PHY MODE DESCRIPTOR (SEE TABLE 263) 

n 



The PARAMETERS SAVEABLE (PS) bit is defined in SPC-4. 

The SPF field shall be set to one to access the long format mode pages. 

The PAGE CODE field shall be set to 19h. 

The SUBPAGE CODE field shall be set to 01 h. 

The PAGE LENGTH field shall be set to (4 + (the value of the NUMBER OF PHYS field) x (the length in bytes of the SAS 
phy mode descriptor)). 

The PROTOCOL IDENTIFIER field shall be set to 6h indicating this is a SAS SSP specific mode page. 

The NUMBER OF PHYS field contains the number of phys in the SAS target device and indicates the number of SAS phy 
mode descriptors that follow. This field shall not be changeable with MODE SELECT. 

A SAS phy mode descriptor shall be included for each phy in the SAS target device (not just the SAS target port), starting 
with the lowest numbered phy and ending with the highest numbered phy. 

Table x defines the SAS phy mode descriptor. 
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Table 263 — SAS phy mode descriptor 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

Reserved 

1 

PHY IDENTIFIER 

2 

RESTRICTED (FOR SMP PHY CONTROL FUNCTION’S PHY OPERATION FIELD) 

3 

Reserved 

4 

Reserved 

ATTACHED DEVICE TYPE 

Reserved 

5 

Reserved 

NEGOTIATED PHYSICAL LINK RATE 

6 

Reserved 

ATTACHED 
SSP INITI¬ 
ATOR 
PORT 

ATTACHED 
STP INITI¬ 
ATOR 
PORT 

ATTACHED 
SMP INITI¬ 
ATOR 
PORT 

Reserved 

7 

Reserved 

ATTACHED 
SSP TAR¬ 
GET PORT 

ATTACHED 
STP TAR¬ 
GET PORT 

ATTACHED 
SMP TAR¬ 
GET PORT 

Reserved 

8 




SAS ADDRESS 




15 









16 



ATTACHED SAS ADDRESS 



23 









24 

ATTACHED PHY IDENTIFIER 

25 




Reserved 




31 









32 

PROGRAMMED MINIMUM PHYSICAL LINK 
RATE 

HARDWARE MINIMUM PHYSICAL LINK RATE 

33 

PROGRAMMED MAXIMUM PHYSICAL LINK 
RATE 

HARDWARE MAXIMUM PHYSICAL LINK RATE 

34 




Reserved 




41 









42 




Vendor specific 




43 









44 




Reserved 




47 










The PHY IDENTIFIER field, ATTACHED DEVICE TYPE field, NEGOTIATED PHYSICAL LINK RATE field, 
ATTACHED SSP INITIATOR PORT bit, ATTACHED STP INITIATOR PORT bit, ATTACHED SMP INITIATOR 
PORT bit, ATTACHED SSP TARGET PORT bit, ATTACHED STP TARGET PORT bit, ATTACHED SMP TAR¬ 
GET PORT bit, SAS ADDRESS field, ATTACHED SAS ADDRESS field, ATTACHED PHY IDENTIFIER, 
HARDWARE MINIMUM PHYSICAL LINK RATE field, and HARDWARE 
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MAXIMUM PHYSICAL LINK RATE field are defined in the SMP DISCOVER function. These fields shall not be 
changeable with MODE SELECT 

The PROGRAMMED MINIMUM PHYSICAL LINK RATE field and PROGRAMMED MAXIMUM PHYSICAL 
LINK RATE field are defined in the SMP PHY CONTROL function. 

4.3.19 Rigid Drive Geometry Parameters page (04h) 

The Rigid Drive Geometry Parameters page implementation is defined in Table 264. This table summarizes the 
function and defines the default value. 

Table 264 — Rigid Drive Geometry Parameters page (04h) 


Bit 

7 

6 

5 

4 

3 

2 

1 

0 

Byte 










Page Descriptor Header 


0 

PS 

Reserved 

PAGE CODE (04h) 

1 

PAGE LENGTH (16h) 


Rigid Drive Geometry Parameters 


2 

NUMBER OF CYLINDERS (MSB) 

3 

NUMBER OF CYLINDERS 

4 

NUMBER OF CYLINDERS (LSB) 

5 

NUMBER OF HEADS 

6,7,8 

STARTING CYLINDER—WRITE PRECOMP 

9,10,11 

STARTING CYLINDER—REDUCED WRITE CURRENT 

12,13 

DRIVE STEP RATE 

14,15,16 

LANDING ZONE CYLINDER 

17 

0 0 0 0 0 0 RPL 

18 

ROTATIONAL OFFSET XXh 

19 

Reserved 

20 

(MSB) MEDIUM ROTATION RATE 

21 

(LSB) 

22 

Reserved 

23 

Reserved 


PS (Parameter Savable) bit 

The Parameter Savable (PS) bit of 1 indicates that page 04 parameter data is savable and is saved when a Format Func¬ 
tion is performed. In some drives an exception exists that applies to bytes 17 and 18. In the exception drives, bytes 17 and 
18 are only saved if the SMP bit in the MODE SELECT command (Table 58) is 1. See individual drive’s Product Manual, 
Volume 1, SCSI bus conditions and miscellaneous features supported.” This PS bit is not applicable to the MODE SELECT 
command. 
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NUMBER OF CYLINDERS field 

The NUMBER OF CYLINDERS field defines the number of physical cylinders used for data storage. This may or may not 
include spare cylinders set aside for flaw reallocation. See individual drive’s Product Manual, Volume 1, which specifies 
what the drive reports. 

The drive uses some additional cylinders for storing drive parameters, defect lists, or for diagnostic purposes. These are 
not accessible by the user. 

NUMBER OF HEADS field 

The NUMBER OF HEADS field indicates the maximum number of data (read/write) heads on the drive. 

STARTING CYLINDER—WRITE PRECOMP, STARTING CYLINDER—REDUCED WRITE CURRENT, DRIVE STEP 
RATE, and LANDING ZONE CYLINDER fields 

Not applicable. 

RPL (rotational position locking) field 

Used for Spindle Synchronization (rotational position locking). 

Rotational Position Locking 
RPL Description 

0Qb Indicates that spindle synchronization is automatic. (Automatic master arbitration is used to determine 
which device in the chain is to be master.) 

01 b The target operates as a synchronized-spindle slave. 

10b The target operates as a synchronized-spindle master. 

11b The target operates as a synchronized-spindle master control (not supported by drive). 

ROTATIONAL OFFSET field 

Rotational skew in the lagging direction used for spindle synchronization. The value XXh given represents a XXh/FFh frac¬ 
tional part of a revolution lagging offset. One revolution lag is maximum. See clause on Synchronous Spindle Operation in 
individual drive’s Product Manual, Volume 1. 

MEDIUM ROTATIORN RATE field 

On MODE SENSE command, these bytes return drive nominal rotation rate in revolutions per minute for synchronous spin¬ 
dle operation. The bytes have no meaning for MODE SELECT. 

See individual drive’s Product Manual, Volume 1, MODE SENSE Data clause, for changeable values. 
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4.3.20 


Unit Attention parameters page (OOh) 


The Unit Attention parameters page is the last page to be reported by the drive. 

Table 265 — Unit Attention parameters page (OOh) 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

PS 


PAGE CODE (OOh) 

1 

PAGE LENGTH (in bytes) 

2 

PM 

SSM 

INQUIRY 

LENGTH 

UNIT 

ATTEN¬ 

TION 

DFUA 

ROUND 

STRICT 

SCSI-2 

3 

Reserved 

SELF 

SEEK 

Reserved 

4 

Reserved JIT3 JIT2 JIT1 JITO 

5 

Reserved 

6 

Reserved 

7 

Reserved 


PS (Parameter Savable) bit 

A Parameter Savable (PS) bit of one indicates that the drive is capable of saving the page in a nonvolatile vendor-specific 
location (used only with MODE SENSE command). 

PAGE LENGTH field 

The PAGE LENGTH field specifies the length in bytes of the mode parameters that follow. If the initiator does not set this 
value to the value that is returned for the page by the MODE SENSE command, the drive shall terminate the command with 
CHECK CONDITION status. The sense key shall be set to ILLEGAL REQUEST with the additional sense code set to 
Invalid Field In Parameter List. The drive is permitted to implement a mode page that is less than the full page length 
defined by this specification, provided no field is truncated and the page length field correctly specifies the actual length 
implemented. If the STRICT bit equals zero and if the page length specified by the initiator is shorter than the actual page 
length, then the parameters are transferred and the command ends with GOOD status if no other items cause the com¬ 
mand to be rejected. 

Caution: Utilization of this forgiving option by a SCSI initiator port that does not analyze the impact of 
the truncation could adversely affect data integrity. 

PM (Performance Mode) bit 

The PM (Performance Mode) bit is used to control the drive’s cache management algorithm to allow best performance in 
different types of systems. It is the initiator’s responsibility to determine which setting is best for that system. 

1 A PM value of 1 indicates that the number of cache segments is fixed to the value set in mode page 08h. 

0 A PM value of 0 indicates that the drive will optimize the number of segments depending on the command activity 

observed by the drive. The number of segments value (in mode page 08h) is ignored with the PM value is 0. 

SSM (enable Synchronous Select Mode) bit 

1 If the enable Synchronous Select Mode (SSM) bit equals one, the drive initiates WDTR and SDTR messages when 
it recognizes that one may be required (after reset, reset message, or power cycle). 

0 If the SSM bit equals zero, the drive does not initiate WDTR or SDTR regardless of negotiated conditions prior to 
reset, reset message, or power cycle. 
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IL (INQUIRY Length) bit 

1 When the INQUIRY Length (IL) bit is set to 1, the standard INQUIRY data available to a host is limited to the 36 
bytes required by the SCSI-2 specification. 

0 When the IL bit is reset (0), 148 bytes of standard INQUIRY data are available. The Additional Length field in byte 4 
of the INQUIRY data is updated to reflect the actual number of additional bytes available. 

UNIT ATTENTION bit 

1 When the UNIT ATTENTION bit is set to 1, then UNIT ATTENTION is logged in sense only; no CHECK CONDITION 
status is presented following any reset. 

0 When this bit is Reset (0), then Check Condition is presented for all affected initiators following a reset until 
REQUEST SENSE is issued by each initiator (as per current operation). 

DFUA (Disable Force Unit Access) bit 

1 When the Disable Force Unit Access (DFUA) bit is set to 1, the drive ignores the FUA bit in READ and WRITE com¬ 
mands. This can result in better drive performance in some circumstances. 

0 When the DFUA is set to 0, the drive obeys the FUA setting in READ and WRITE commands. 

ROUND bit 

1 When the ROUND bit equals one, the drive treats and reports rounded parameters as described in SPC-4. 

0 When ROUND equals zero, the drive shall round the parameter and handle command completion reporting as if the 

parameter had not been rounded. 

STRICT bit 

1 When the STRICT bit is a one, the drive checks for initiator attempts to change unchangeable parameters. If the 
drive detects an attempt, it rejects the command in the standard way, i.e., CHECK CONDITION status from drive, 
REQUEST SENSE from the initiator, and Illegal Request Sense key (5h) back from the drive. 

0 When the STRICT bit is zero, the drive ignores the values of the unchangeable parameters in a MODE SELECT 
command. The drive does not reject the command trying to change unchangeable parameters. 

SCSI-2 bit 

1 When set to one, the SCSI-2 bit changes the following SCSI-3 features from their SCSI-3 definition to the SCSI-2 
definition. 

0 When S2 equals zero, the following features remain as specified in other portions of this specification: 

a) Control Mode Page (OAh) Length from OAh to 06h. 

b) Caching Page (08h) Length from 12h to OAh. 

Reserved bits 

These bits are reserved for future compatibility with Seagate host adapters. Though they presently may be changeable, 

these bits do not control anything, unless the individual drive’s Product Manual, Volume 1, indicates that they do and 

defines their use in the MODE SENSE Data section. 

Reserved bytes 

See individual drive’s Product Manual, Volume 1, MODE SENSE Data section for a table showing codes that indicate which 

of these bits are changeable by the host using the MODE SELECT command. 

Self Seek bit 

1 If the Self Seek bit is set to one, the drive will enter self seek mode for testing purposes. Such testing could include, 
but is not limited to, power dissipation and acoustics. While in this mode, the drive will accept SCSI commands and 
will process them in between the self seek operations, including a MODE SELECT to turn this bit back off. As such, 
this bit should be off for normal drive operations. 

0 If this bit is set to zero, the drive will not self seek; normal operating mode. 
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JIT (Just in Time) bits 

The four JIT (Just In Time) bits allow you to enable and disable certain seek speeds. JITO represents the fastest seek type 
used by the drive, JIT1 represents the second fastest, JIT2 represents the third fastest, and JIT3 represents the slowest 
seek type. You can use these bits to reduce acoustics by disabling the fastest seeks. This can also reduce power consump¬ 
tion (from seek activity). These JIT settings only affect user read and write operations. Background drive operations and 
user seek commands will always use the fastest seek type. When the bit is set to 1, the drive is allowed to use this seek 
type in its seek speed algorithm. When the bit is set to 0, the drive is not allowed to use this seek type in its seek speed 
algorithm. If all JIT bits are set to zero, the drive enables JITO only. If all bits are set to one, the drive firmware selects the 
slowest (quietest) seek speed that does not hurt performance. 

4.3.21 Verify Error Recovery mode page (07h) 

The Verify Error Recovery mode page (see table 266) specifies the error recovery parameters the device 
server shall use during the VERIFY command and the verify operation of the WRITE AND VERIFY command. 


Table 266 — Verify Error Recovery mode page 


Bit 

Byte 

7 

6 

5 4 

3 2 1 

0 

0 

PS 

Reserved 

PAGE CODE (07h) 

1 

PAGE LENGTH (OAh) 

2 

Reserved formerly 

ERROR RECOVERY BITS 

AWRE ARRE TB RC 

EER PER DTE DCR 

3 

VERIFY RETRY COUNT 

4 

Obsolete formerly CORRECTION SPAN 

5 


Reserved formerly 

HEAD OFFSET COUNT (Byte 5), DATA STROBE OFFSET COUNT (Byte 6) 
and WRITE RETRY COUNT (Byte 8) Bytes 7 and 9 were Reserved 


9 



10 

(MSB) 

VERIFY RECOVERY TIME LIMIT 


11 


(LSB) 


PS (Parameters Savable) bit 

The parameters savable (PS) bit is only used with the MODE SENSE command. This bit is reserved with the MODE 
SELECT command. A PS bit set to one indicates that the device server is capable of saving the mode page in a non-vola¬ 
tile vendor-specific location. 

AWRE bit 

The AWRE bit as defined in the Read-Write Error Recovery mode page (see 4.3.21) applies to the WRITE AND VERIFY 
command. The VERIFY command shall not perform automatic reallocation. 

EER bit, PER bit, DTE bit, and DCR bit 

The EER bit, the PER bit, the DTE bit, and the DCR bit (i.e., the error recovery bits) are defined in 4.3.8. The combinations 
of these bits are defined in table 227 (see 4.3.8). 

VERIFY RETRY COUNT field 

The VERIFY RETRY COUNT field specifies the number of times that the device server shall attempt its recovery algorithm 
during a verify operation. 
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VERIFY RECOVERY TIME LIMIT field 


The VERIFY RECOVERY TIME LIMIT field specifies in milliseconds the maximum time duration that the device server 
shall use error recovery procedures to recover data for an individual logical block. The device server may round this value 
as described in SPC-4. 

When both a retry count and a recovery time limit are specified, the one that requires the least time for data 
error recovery actions shall have priority. 

To disable all types of correction and retries the application client should set the EER bit to zero, the PER bit to 
one, the DTE bit to one, the DCR bit to one, the VERIFY RETRY COUNT field to OOh, and the VERIFY 
RECOVERY TIME LIMIT field to OOOOh. 
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4.4 


Vital product data parameters 


4.4.1 Vital product data parameters overview and page codes 

This subclause describes the vital product data (VPD) page structure and the VPD pages (see table 267) that 
are applicable to all SCSI devices. These VPD pages are returned by an INQUIRY command with the EVPD 
bit set to one (see clause 3.6) and contain vendor specific product information about a logical unit and SCSI 
target device. The vital product data may include vendor identification, product identification, unit serial num¬ 
bers, device operating definitions, manufacturing data, field replaceable unit information, and other vendor 
specific information. This standard defines the structure of the vital product data, but not the contents. 


Table 267 — Vital product data page codes 


Page code 

VPD Page Name 

Reference 

Support 

Requirements 

01 h - 7Fh 

ASCII Information 

4.4.2 

Optional 

83 h 

Device Identification 

4.4.7 

Mandatory 

86h 

Extended INQUIRY Data 


Optional 

85 h 

Management Network Addresses 


Optional 

87h 

Mode Page Policy 


Optional 

81 h 

Obsolete 



82h 

Obsolete 



88h 

SCSI Ports 


Optional 

84 h 

Software Interface Identification 


Optional 

OOh 

Supported VPD Pages 

4.4.9 

Mandatory 

80h 

Unit Serial Number 

4.4.10 

Optional 

89h - AFh 

Reserved 



BOh - BFh 

(See specific device type) 



COh - FFh 

Vendor specific 

4.4.3 - 4.4.8 
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4.4.2 


ASCII Information VPD page (01 h - 7Fh) 


The ASCII Information VPD page (see table 268) contains information for the field replaceable unit code 
returned in the sense data (see 2.2.9). 

Table 268 — ASCII Information VPD page 


Bit 

Byte 

7 6 5 

4 3 2 1 0 

0 

PERIPHERAL QUALIFIER 

PERIPHERAL DEVICE TYPE 

1 

PAGE CODE (01H - 7Fh) 

2 

Reserved 

3 

PAGE LENGTH (N-3) 

4 

ASCII LENGTH (M-4) 

5 

(MSB) ASCII INFORMATION 

m 

(LSB) 

m+1 

Vendor specific information 

n 



PERIPHERAL QUALIFIER and the PERIPHERAL DEVICE TYPE fields 

The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in STANDARD INQUIRY 
DATA (see). 

PAGE CODE field 

The PAGE CODE field contains the same value as in the PAGE OR OPERATION CODE field of the INQUIRY CDB (see 
3.6) and is associated with the FIELD REPLACEABLE UNIT CODE field returned in the sense data. 

Note. The FIELD REPLACEABLE UNIT CODE field in the sense data provides for 255 possible codes, while the PAGE 
CODE field provides for only 127 possible codes. For that reason it is not possible to return ASCII Information 
VPD pages for the upper code values. 

PAGE LENGTH field 

The PAGE LENGTH field specifies the length of the following VPD page data. The relationship between the PAGE 
LENGTH field and the CDB ALLOCATION LENGTH field is defined in 2.2.6. 

ASCII LENGTH field 

The ASCII LENGTH field specifies the length in bytes of the ASCII INFORMATION field that follows. A value of zero in this 
field indicates that no ASCII information is available for the specified page code. The relationship between the ASCII 
LENGTH field and the CDB ALLOCATION LENGTH field is defined in 2.2.6. 

The ASCII INFORMATION field contains ASCII information concerning the field replaceable unit identified by the page 
code. The data in this field shall be formatted in one or more character string lines. Each line shall contain only graphic 
codes (i.e., code values 20h through 7Eh) and shall be terminated with a NULL (OOh) character. 

The contents of the vendor specific information field is not defined in this manual. 


SCSI Commands Reference Manual, Rev. A 


319 




4.4.3 Date Code page (Cl h) 

Table 269 — ETF Log Date Code page (Clh) 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

PERIPHERAL QUALIFIER 

PERIPHERAL DEVICE TYPE 

1 

PAGE CODE (Clh) 

2 

OOh 

3 

PAGE LENGTH (lOh) 

4 

(MSB) 












ETF LOG DATE IN ASCII 




11 








(LSB) 

12 

(MSB) 












COMPILE DATE CODE 




19 








(LSB) 


PERIPHERAL QUALIFIER field and PERIPHERAL DEVICE TYPE field 

The PERIPHERAL QUALIFIER field and PERIPHERAL DEVICE TYPE field value of OOh indicates a direct-access device 
(magnetic disc) is connected to this logical unit. 

PAGE CODE field 

PAGE CODE (Cl h) provides the date code from the drive defect list. 

PAGE LENGTH field 

The PAGE LENGTH field specifies the length of the product date code. If the ALLOCATION LENGTH is too small to transfer 
all of the page, the page length shall not be adjusted to reflect the truncation. 

ETF Log field 

The ETF Log date code field contains ASCII data. The data is stored in the format MMDDYYYY. Leading ASCII zero char¬ 
acters are added to single-digit months or days. 

COMPILE DATE CODE field 

The COMPILE DATE CODE field contains 8 ASCII bytes of data for a date of the form MMDDYYYY. 
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4.4.4 


Device Behavior page (C3h) 


The Device Behavior page (see table 270) will be used by the regression tests to determine what behavior 
should be expected from a particular firmware package. 

Table 270 — Device Behavior page (C3h) 


Bit 

Byte 

7 6 5 

4 3 2 1 0 

0 

PERIPHERAL QUALIFIER 

PERIPHERAL DEVICE TYPE 

1 

PAGE CODE (C3h) 

2 

Reserved 

3 

PAGE LENGTH 

4 

VERSION NUMBER 

5 

BEHAVIOR CODE 

6 

BEHAVIOR CODE VERSION NUMBER 

7 

22 

ASCII FAMILY NUMBER (16 bytes) 

23 

NUMBER OF INTERLEAVES 

24 

DEFAULT NUMBER OF CACHE SEGMENTS 

25+ 

Feature Flags and Additional Byte Fields will go here but are undefined at this time. 


PERIPHERAL QUALIFIER field and PERIPHERAL DEVICE TYPE fields 

The PERIPHERAL QUALIFIER field and PERIPHERAL DEVICE TYPE field value of OOh indicates a direct-access device 
(magnetic disc) is connected to this logical unit. 

PAGE CODE field 

The PAGE CODE(C3h) field identifies the page as the Device Behavior page. 

PAGE LENGTH field 

PAGE LENGTH defines the length of the Device Behavior information in bytes. If the ALLOCATION LENGTH is too small to 
transfer all of the page, the page length shall not be adjusted to reflect the truncation. 

VERSION NUMBER field 

The VERSION NUMBER is a one-byte short form notation for the 24-byte assignment in the Firmware Numbers page. Ver¬ 
sion Numbers are registered by Engineering services. 

BEHAVIOR CODE and BEHAVIOR CODE VERSION NUMBER fields 

The BEHAVIOR CODE and BEHAVIOR CODE VERSION NUMBER are jointly assigned by the Firmware Engineering 
Managers of all SCSI design locations. 

ASCII FAMILY NUMBER field 

The ASCII FAMILY NUMBER field contains the drive model number. The data is left-aligned within this field. 

NUMBER OF INTERLEAVES field 

The NUMBER OF INTERLEAVES field indicates the number of data interleaves used by the ECC correction algorithm. 
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DEFAULT NUMBER OF CACHE SEGMENTS field 

The DEFAULT NUMBER OF CACHE SEGMENTS field gives the number of segments into which the host requests the 
drive divide the cache. 

4.4.5 Extended INQUIRY Data VPD page (86h) 

The Extended INQUIRY Data VPD page (see table 271) provides the application client with a means to obtain 
information about the logical unit. 

Table 271 — Extended INQUIRY Data VPD page 


Bit 

Byte 

7 6 5 

4 3 

2 

1 

0 

0 

PERIPHERAL QUALIFIER 

PERIPHERAL DEVICE TYPE 

1 

PAGE CODE (86h) 

2 

Reserved 

3 

PAGE LENGTH (3Ch) 

4 

Reserved SPT 

GRDCHK 

APPCHK 

REFCHK 

5 

Reserved GROUP_SUP PRIOR_SUP 

HEADSUP 

ORDSUP 

SIMPSUP 

6 

Reserved 

NV_SUP 

V_SUP 

7 


Reserved 
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The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are as defined in 3.6.2. 

PAGE LENGTH field 

The PAGE LENGTH field specifies the length of the following VPD page data and shall be set to 60. The relationship 
between the PAGE LENGTH field and the CDB ALLOCATION LENGTH field is defined in 2.2.6. 

SPT (Supported Protection Type) field 

A supported protection type (SPT) field (see table 272) indicates the type of protection the logical unit supports. The SPT 
field shall be ignored if the PROTECT bit is set to zero. 

Table 272 — SPT field 


Code 

Definition 

000b 

The logical unit supports type 1 protection (see SBC-3). 

001b 

The logical unit supports type 2 protection (see SBC-3). 

010b 

Reserved 

011b 

The logical unit supports type 3 protection (see SBC-3). 

100b - 111b 

Reserved 


GRD_CHK (Guard Check) bit 

0 A guard check (GRD_CHK) bit set to zero indicates that the device server does not check the LOGICAL BLOCK 
GUARD field in the protection information (see SBC-2), if any. 
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1 A GRD_CHK bit set to one indicates that the device server checks the LOGICAL BLOCK GUARD field in the protec¬ 
tion information, if any. 

APP_CHK (Application Tag Check) bit 

0 An application tag check (APPCHK) bit set to zero indicates that the device server does not check the LOGICAL 
BLOCK APPLICATION TAG field in the protection information (see SBC-2), if any. 

1 An APP CHK bit set to one indicates that the device server checks the LOGICAL BLOCK APPLICATION TAG field 
in the protection information, if any. 

REF_CHK (Reference Tag Check) bit 

0 A reference tag check (REF CHK) bit set to zero indicates that the device server does not check the LOGICAL 
BLOCK REFERENCE TAG field in the protection information (see SBC-2), if any. 

1 A REF_CHK bit set to one indicates that the device server checks the LOGICAL BLOCK REFERENCE TAG field in 
the protection information, if any. 

GROUP_SUP (Grouping Function Supported) bit 

0 A grouping function supported (GROUP_SUP) bit set to one indicates that the grouping function (see SBC-2) is 
supported by the device server. 

1 A GROUP_SUP bit set to zero indicates that the grouping function is not supported. 

PRIOR SUP (Priority Supported) bit 

1 A priority supported (PRIOR_SUP) bit set to one indicates that task priority (see SAM-3) is supported by the logical 
unit. 

0 A PRIOR_SUP bit set to zero indicates that task priority is not supported. 

HEADSUP (Head of Queue Supported) bit 

1 A head of queue supported (HEADSUP) bit set to one indicates that the HEAD OF QUEUE task attribute (see SAM- 
3) is supported by the logical unit. 

0 A HEADSUP bit set to zero indicates that the HEAD OF QUEUE task attribute is not supported. If the HEADSUP bit 
is set to zero, application clients should not specify the HEAD OF QUEUE task attribute as an Execute Command 
procedure call argument. 

ORDWUP (Ordered Supported) bit 

1 An ordered supported (ORDSUP) bit set to one indicates that the ORDERED task attribute (see SAM-3) is sup¬ 
ported by the logical unit. 

0 An ORDSUP bit set to zero indicates that the ORDERED task attribute is not supported. If the ORDSUP bit is set to 
zero, application clients should not specify the ORDERED task attribute as an Execute Command procedure call 
argument. 

SIMPSUP (Simple Supported) bit 

1 A simple supported (SIMPSUP) bit set to one indicates that the SIMPLE task attribute (see SAM-3) is supported by 
the logical unit. Logical units that support the full task management model (see SAM-3) shall set the SIMPSUP bit to 
one. 

0 A SIMPSUP bit set to zero indicates that the SIMPLE task attribute is not supported. If the SIMPSUP bit is set to 
zero, application clients should not specify the SIMPLE task attribute as an Execute Command procedure call argu¬ 
ment. 

Note. SAM-3 defines how unsupported task attributes are processed. 

NVSUP bit 

1 An NV SUP bit set to one indicates that the device server supports a non-volatile cache and that the applicable 
command standard defines features using this cache (e.g., the FUA_NV bit in SBC-2). 

0 An NV SUP bit set to zero indicates that the device server may or may not support a non-volatile cache. 
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V_SUP bit 

1 A VSUP bit set to one indicates that the device server supports a volatile cache and that the applicable command 
standard defines features using this cache (e.g., the FUA bit in SBC-2). 

0 An V SUP bit set to zero indicates that the device server may or may not support a volatile cache. 

4.4.6 Firmware Numbers page (COh) 

Table 273 applies to drives that do not supply a servo RAM Release number and date and a ROM Release 
date. Table 274 applies to model families other than those covered by Table 273. 


Table 273 — Firmware Numbers page (COh) 


Bit 

Byte 

7 6 

5 4 3 2 1 0 

0 

PERIPHERAL QUALIFIER 

PERIPHERAL DEVICE TYPE 

1 

PAGE CODE (COh) 

2 

OOh 

3 

PAGE LENGTH (18h) 

4 

11 

SCSI FIRMWARE RELEASE NUMBER 

12 

19 

ASCII space characters 

20 

27 

Servo ROM Release Number 


PERIPHERAL QUALIFIER field and PERIPHERAL DEVICE TYPE fields 

The PERIPHERAL QUALIFIER field and PERIPHERAL DEVICE TYPE field value of OOh indicates a direct-access device 
(magnetic disc) is connected to this logical unit. 

PAGE CODE field 

PAGE CODE (COh) provides the Firmware Release numbers for the drive (see table 274). 

PAGE LENGTH field 

The PAGE LENGTH field specifies the length of the product firmware numbers. If the ALLOCATION LENGTH is too small to 
transfer all of the page, the page length shall not be adjusted to reflect the truncation. 

SCSI FIRMWARE RELEASE NUMBER field 

The SCSI FIRMWARE RELEASE NUMBER field contains ASCII data. The least significant ASCII character of the drive 
firmware number shall appear as the last byte of a successful data transfer. 


Note. The above information is for drives that return only 28 bytes. For drives that return more than 28 
bytes, see Table 274. 
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Table 274 — Firmware Numbers page (COh) (Applies to model families not covered by Table 273) 



The PERIPHERAL QUALIFIER field and PERIPHERAL DEVICE TYPE field value of OOh indicates a direct-access device 
(magnetic disc) is connected to this logical unit. 

PAGE CODE field 

PAGE CODE (COh) provides the Firmware Release numbers for the drive. 
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PAGE LENGTH field 

The PAGE LENGTH field specifies the length of the product firmware numbers. If the ALLOCATION LENGTH is too small to 
transfer all of the page, the page length shall not be adjusted to reflect the truncation. 

SCSI FIRMWARE RELEASE NUMBER fields 

The SCSI FIRMWARE RELEASE NUMBER fields contain ASCII data. The least significant ASCII character of the Drive 
firmware number shall appear as the last byte of a successful data transfer. 

SERVO ROM RELEASE DATE fields 

Applies to model families that return 36 bytes rather than 28. Newer drive models return 60 bytes. Servo firmware RAM and 
ROM Release dates are added in some models. See “Vital Product Data pages supported” table in the Product Manual, 
Volume 1, that applies to the drive in question. 

SERVO ADAPTIVE PARAMETERS (SAP) fields 

Servo Adaptive Parameters (SAP) are created independently from the servo firmware. Thus, they have their own release 
information. The SAP Firmware Release Number field contains ASCII data. 

SAP MANUFACTURING KEY field 

The SAP MANUFACTURING KEY field contains a binary code used by manufacturing to identify the SAP. 

SERVO FIRMWARE PRODUCT FAMILY and PRODUCT FAMILY MEMBER IDs field 

The high order word of the SERVO FIRMWARE PRODUCT FAMILY and PRODUCT FAMILY MEMBER IDs field contains a 
binary code which corresponds to the Servo Firmware Family ID. The low order word of this field contains a binary code 
which corresponds to the Product Family Member ID. 

Note. Applies to model families that return 59 bytes rather than 35 or 28. Servo firmware RAM and ROM 
Release dates are added, plus SAP firmware. See Vital Product Data pages supported” table in the 
Product Manual, Volume 1, that applies to the drive in question. 
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4.4.7 


Device Identification VPD page (83h) 


The Device Identification VPD page (see table 275) provides the means to retrieve zero or more identification 
descriptors applying to the logical unit. Logical units may have more than one identification descriptor (e.g., if 
several types or associations of identifier are supported). Device identifiers consist of one or more of the follow¬ 
ing: 

• Logical unit names; 

• SCSI target port identifiers; 

• SCSI target port names; 

• SCSI target device names; 

• Relative target port identifiers; 

• SCSI target port group number; or 

• Logical unit group number. 

Identification descriptors shall be assigned to the peripheral device (e.g., a disc drive) and not to the currently 
mounted media, in the case of removable media devices. Operating systems are expected to use the identifi¬ 
cation descriptors during system configuration activities to determine whether alternate paths exist for the 
same peripheral device. 


Table 275 — Device Identification VPD page 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

PERIPHERAL QUALIFIER 

PERIPHERAL DEVICE TYPE 

1 

PAGE CODE (83h) 

2 

MSB 

PAGE LENGTH (n-3) 


3 


LSB 


DENTIFICATION DESCRIPTOR LIST 

4 


IDENTIFICATION DESCRIPTOR (First) 

















rz: 

IDENTIFICATION DESCRIPTOR (Last) 


PERIPHERAL QUALIFIER and the PERIPHERAL DEVICE fields 

The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE field are as defined in Table 268. 

PAGE CODE field 

PAGE CODE (83h) provides a method to retrieve various identification descriptors applying to the logical unit. 

PAGE LENGTH field 

The PAGE LENGTH field specifies the length of the following VPD page data. 
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IDENTIFICATION DESCRIPTOR LIST field 


The IDENTIFICATION DESCRIPTOR LIST provides a list of Identification Descriptor information, the format of which is 
given in Table 276. 

IDENTIFICATION DESCRIPTOR field 

Each IDENTIFICATION DESCRIPTOR (see Table 276) contains information identifying the logical unit, physical device, or 
access path used by the command and returned parameter data. 

Table 276 — Identification Descriptor 


Bit 

Byte 

7 6 5 4 

3 2 10 

0 

PROTOCOL IDENTIFIER 

CODE SET 

1 

PIV Reserved ASSOCIATION 

IDENTIFIER TYPE 

2 

Reserved 

3 

IDENTIFIER LENGTH (n-3) 

4 

IDENTIFIER 

n 



PROTOCOL IDENTIFIER field 

The PROTOCOL IDENTIFIER field may indicate the SCSI transport protocol to which identification descriptor applies. If the 
ASSOCIATION field contains a value other than 1h or 2h or the PIV bit is set to zero, then the PROTOCOL IDENTIFIER 
field should be ignored. If the ASSOCIATION field contains a value of 1h or 2h and the PIV bit is set to one, then the PRO¬ 
TOCOL IDENTIFIER field shall contain one of the values shown in table 238 (see 7.5.1) to indicate the SCSI transport pro¬ 
tocol to which identification descriptor applies. 

CODE SET field 

The CODE SET field specifies the code set used for the identifier field, as described in Table 277. This field is intended to 
be an aid to software that displays the identifier field. 

Table 277 — Code Set 


Value 

Description 

Oh 

Reserved 

1h 

The IDENTIFIER field shall contain binary values 

2h 

The IDENTIFIER field shall contain ASCII graphic codes (i.e., code values 20h through 7Eh) 

3h - Fh 

Reserved 


PIV (Protocol Identifier Valid) bit 

0 A protocol identifier valid (PIV) bit of zero indicates the PROTOCOL IDENTIFIER field should be ignored. If the 
ASSOCIATION field contains a value of 1h or 2h then a PIV bit set to one indicates the PROTOCOL IDENTIFIER 
field contains a valid protocol identifier selected from the values shown in table 278. If the ASSOCIATION field con¬ 
tains a value other than 1 h or 2h then the PIV bit should be ignored. 


Table 278 — PROTOCOL IDENTIFIER values 


Protocol Identifier 

Description 

Protocol Standard 

Oh 

Fibre Channel 

FCP-2 

1h 

Parallel SCSI 

SPI-4 

2h 

SSA 

SSA-S3P 
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Table 278 — PROTOCOL IDENTIFIER values 


Protocol Identifier 

Description 

Protocol Standard 

3h 

IEEE 1394 

SBP-2 

4h 

Remote Direct Memory Access (RDMA) 

SRP 

5h 

Internet SCSI 

iSCSI 

6h 

SAS Serial SCSI Protocol 

SAS 

7h - Fh 

Reserved 



ASSOCIATION field 

The ASSOCIATION field indicates the entity that the Identification descriptor describes. If a physical or logical device 
returns an Identification descriptor with the ASSOCIATION field set to Oh, it shall return the same descriptor when it is 
accessed through any other path. 

The ASSOCIATION field specifies the entity with which the Identifier field is associated, as described in Table 279. 

Table 279 — ASSOCIATION field 


Value 

Description 

Oh 

The IDENTIFIER field is associated with the addressed physical or logical device 

1h 

The IDENTIFIER field is associated with the port that received the request 

2h 

The IDENTIFIER field is associated with the SCSI target device that contains the addressed logical unit. 

‘3h 

Reserved 


IDENTIFIER TYPE field 

The IDENTIFIER TYPE field specifies the format and assignment authority for the identifier, as described in tables 280 and 
281. 


Table 280 — IDENTIFIER Type field 


Value 

Description 

Oh 

No assignment authority was used and consequently there is no guarantee that the identifier is globally 
unique (i.e., the identifier is vendor specific). 

1h 

The first 8 bytes of the IDENTIFIER field are a Vendor ID (see annex C). The organization associated with the 
Vendor ID is responsible for ensuring that the remainder of the identifier field is unique. One recommended 
method of constructing the remainder of the identifier field is to concatenate the product identification field 
from the standard INQUIRY data field and the product serial number field from the unit serial number page. 

2h 

The IDENTIFIER field contains a Canonical form IEEE Extended Unique Identifier, 64-bit (EUI-64). In this 
case, the identifier length field shall be set to 8. Note that the IEEE guide-lines for EUI-64 specify a method for 
unambiguously encapsulating an IEEE 48-bit identifier within an EUI-64. 

3h 

The IDENTIFIER field contains an FC-PH, FC-PH3 or FC-FS Namejdentifier. Any FC-PH, FC-PH3 or FC- 
FS identifier may be used, including one of the four based on a Canonical form IEEE companyjd. 

4h 

If the ASSOCIATION field contains 1 h, the Identifier value contains a four-byte binary number identifying the 
port relative to other ports in the device using the values shown Table 279. The CODE SET field shall be set 
to 1 h and the IDENTIFIER LENGTH field shall be set to 4h. If the ASSOCIATION field does not contain 1 h, 
use of this identifier type is reserved. 

5h 

If the Association value is 1 h, the Identifier value contains a four-byte binary number identifying the port rela¬ 
tive to other ports in the device using the values shown Table 279. The CODE SET field shall be set to 1 h and 
the IDENTIFIER LENGTH field shall be set to 4h. If the ASSOCIATION field does not contain 1 h, use of this 
identifier type is reserved. 
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Value 

Description 

6h 

If the ASSOCIATION value is Oh, the IDENTIFIER value contains a four-byte binary number identifying the 
port relative to other ports in the device using the values shown Table 279. The CODE SET field shall be set 
to 1 h and the IDENTIFIER LENGTH field shall be set to 4h. If the ASSOCIATION field does not contain Oh, 
use of this identifier type is reserved. 

7h 

The MD5 logical unit identifier shall not be used if a logical unit provides unique identification using identifier 
types 2h or 3h. A bridge device may return a MD5 logical unit identifier type for that logical unit that does not 
support the Device Identification VPD page. 

8h - Fh 

Reserved. 


IDENTIFIER LENGTH field 

The IDENTIFIER LENGTH field specifies the length in bytes of the IDENTIFIER field. If the ALLOCATION LENGTH field of 
the command descriptor block is too small to transfer all of the identifier, the identifier length shall not be adjusted to reflect 
the truncation. 

IDENTIFIER field 

The IDENTIFIER field contains the identifier as described by the Association, Identifier Type, CODE SET, and IDENTIFIER 
LENGTH fields. The example described in this clause and shown in Table 281 is not a normative part of this manual. This 
example of a complete device identification VPD page assumes that the product is a direct-access device with an T10 Ven¬ 
dor ID of “XYZ_Corp,” a product identification of “Super Turbo Disk,” and a product serial number of “2034589345.” Further¬ 
more, it is assumed that the manufacturer has been assigned a 24-bit IEEE companyjd of OlABCDh by the IEEE 
Registration Authority Committee and that the manufacture has assigned a 24-bit extensionjdentifier of 234567h to this 
logical unit. The combined 48-bit identifier is reported in the 64-bit format as defined by the IEEE 64-bit Global Identifier 
(EUI-64) standard. The data returned in the device identification VPD page for this logical unit is shown in Table 281. 


Table 281 — Device Identification page example 


Bytes 

Hexadecimal values 

ASCII values 

00-15 

16-31 

32-47 

48-53 

00 83 00 32 02 01 00 22 58 59 5 5F 43 6 72 70 

53 75 70 65 72 20 54 75 72 62 A 20 44 F 73 6B 

32 30 33 34 35 38 39 33 34 35 6 02 00 69 01 AB 

C F F 23 45 67 F 08 

D F F 01 

...2...XYZ_Corp [5] 
Super Turbo Disk 
2034589345. 

Notes. 

a) Non-printing ASCII characters are shown as 

b) Byte 00 is the beginning of the VPD page (see Table 267). 

c) Byte 04 is the beginning of the Identification descriptor for the Vendor ID based identifier (Identifier type 1 
see Table 280). 

d) Byte 42 is the beginning of the Identification Descriptor for the EUI-64 identifier (Identifier type 2, see Table 
280). 

e) For Seagate devices, this will say “Seagate.” 


4.4.8 Jumper Settings page (C2h) 


Table 282 — Jumper Settings page (C2h) 


Bit 

Byte 

7 

6 

5 

4 

3 

2 

1 

0 

0 

PERIPHERAL QUALIFIER 

PERIPHERAL DEVICE TYPE 

1 

PAGE CODE (C2h) 
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Bit 

Byte 

7 6 5 4 3 2 1 

0 

2 

OOh 

3 

PAGE LENGTH (02h) 

4 

DS MS WP PE DRIVE ID 

5 

Reserved 

TE 


PERIPHERAL QUALIFIER and PERIPHERAL DEVICE TYPE fields 

The PERIPHERAL QUALIFIER field and PERIPHERAL DEVICE TYPE field value of OOh indicates a direct-access device 
(magnetic disc) is connected to this logical unit and are defined in Table 268. 

PAGE CODE field 

PAGE CODE (C2h) provides all the jumper settings for the drive. The bits in byte 4 indicate which jumpers are on. 

PAGE LENGTH field 

The PAGE LENGTH field specifies the length of the Jumper Setting page. If the ALLOCATION LENGTH is too small to 
transfer all of the page, the page length shall not be adjusted to reflect the truncation. 

DS (Delayed Motor Start) bit 

The Delayed Motor Start (DS) bit when set to 1 indicates that this jumper is on. 

MS (Motor Start) bit 

The Motor Start (MS) bit when set to 1 indicates that the jumper is on. 

WP (Write Protect) bit 

The Write Protect (WP) bit when set to 1 indicates that the write protect jumper is on. 

PE (Parity Enable) and PD (Parity Disable) bits 

On some drives, Parity Enable (PE) bit when set to 1 indicates that SCSI parity error checking jumper is on. Other drives 
have a PD (PARITY DISABLE) jumper, where Parity is enabled when the jumper is off. See individual drive's Product Man¬ 
ual, Volume 1, or Installation Guide for information on how the drive of interest is set up. 

Drive ID field 

The Drive ID is shown below in Table 283. Bit 3 is the most significant bit and bit 0 is the least significant bit. 


Table 283 — Drive ID bit 
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Table 283 — Drive ID bit 


Bit 2 

0 


BitO 

o - 


Drive ID 

10 

11 

12 

13 

14 

15 


TE (Terminator Enable) bit 

Terminator Enable (TE) is not used on all drives. See individual drive’s Product Manual, Volume 1, for applicability. 
Note. It is not presently possible to return information on the Terminator Power (TP) jumpers. 


332 


SCSI Commands Reference Manual, Rev. A 




4.4.9 Supported Vital Product Data pages (OOh) 

This clause contains a list of the vital product data page codes supported by the target or logical unit (see Table 
284). If a target supports any vital product data pages, it also shall support this vital product data page. 

Table 284 — Supported Vital Product Data pages 


Bit 

Byte 

7 6 5 

4 3 2 1 0 

0 

PERIPHERAL QUALIFIER 

PERIPHERAL DEVICE TYPE 

1 

PAGE CODE (OOh) 

2 

Reserved 

3 

PAGE LENGTH (n-3) 

4 

SUPPORTED PAGE LIST 




Note. The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in Table 268. 

PAGE CODE field 

PAGE CODE (OOh) provides a list of all Vital Product data pages supported by the drive. 

PAGE LENGTH field 

The PAGE LENGTH field specifies the length of the SUPPORTED PAGE LIST. If the ALLOCATION LENGTH is too small to 
transfer all of the page, the page length shall not be adjusted to reflect the truncation. 

SUPPORTED PAGE LIST field 

The SUPPORTED PAGE LIST field shall contain a list of all vital product data page codes (see clause 4.4.1) implemented 
for the target or logical unit in ascending order beginning with page code OOh. 
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4.4.10 Unit Serial Number page (80h) 

This page provides a product serial number for the target or logical unit. See Table 285 following. 

Table 285 — Unit Serial Number page (80h) 


Bit 

Byte 

7 6 5 

4 3 2 1 0 

0 

PERIPHERAL QUALIFIER 

PERIPHERAL DEVICE TYPE 

1 

PAGE CODE (80h) 

2 

Reserved 

3 

PAGE LENGTH 

4 - n 

Product Serial Number 


The PERIPHERAL QUALIFIER field and the PERIPHERAL DEVICE TYPE field are defined in Table 268. 

PAGE CODE field. 

The PAGE LENGTH field specifies the length in bytes of the product serial number page. Older products that only support 
the Product Serial Number parameter will have a page length of 08h, while newer products that support both parameters 
will have a page length of 14h. If the ALLOCATION LENGTH is too small to transfer all of the page, the page length shall 
not be adjusted to reflect the truncation. 

The Product Serial Number field contains ASCII data that is vendor-assigned serial number. The least signifi¬ 
cant ASCII character of the serial number shall appear as the last byte in the Data-In Buffer. If the product 
serial number is not available, the target shall return ASCII spaces (20h) in this field. 
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